表示するコードは Generics クラスを使用しようとしていますが、型が含まれていません。
Delphi の以前のバージョンでコンパイラが宣言から型を推測するかどうかはわかりませんが、通常は次のように型を宣言する必要があります。
uses Generics.Defaults, Generics.Collections;
...
sortedDictKeys := TList<Integer>.Create(dict.Keys);
try
sortedDictKeys.Sort(TComparer<Integer>.Construct(
function (const L, R: integer): integer
begin
result := R - L;
end
)) ;
for i in sortedDictKeys do
log.Lines.Add(Format('%d, %s', [i, dict.Items[i]]));
finally
sortedDictKeys.Free;
end;
リンクされた about.com の記事からコードを取得し、コンパイルするようにしましたが、テストしませんでした。
コメントで要求されているように、完全な関数は次のようになります。
var
dict : TDictionary<integer, char>;
sortedDictKeys : TList<integer>;
i, rnd : integer;
c : char;
begin
log.Clear;
log.Text := 'TDictionary usage samples';
Randomize;
dict := TDictionary<integer, char>.Create;
try
//add some key/value pairs (random integers, random characters from A in ASCII)
for i := 1 to 20 do
begin
rnd := Random(30);
if NOT dict.ContainsKey(rnd) then dict.Add(rnd, Char(65 + rnd));
end;
//remove some key/value pairs (random integers, random characters from A in ASCII)
for i := 1 to 20 do
begin
rnd := Random(30);
dict.Remove(rnd);
end;
//loop elements - go through keys
log.Lines.Add('ELEMENTS:');
for i in dict.Keys do
log.Lines.Add(Format('%d, %s', [i, dict.Items[i]]));
//do we have a "special" key value
if dict.TryGetValue(80, c) then
log.Lines.Add(Format('Found "special", value: %s', [c]))
else
log.Lines.Add(Format('"Special" key not found', []));
//sort by keys ascending
log.Lines.Add('KEYS SORTED ASCENDING:');
sortedDictKeys := TList<integer>.Create(dict.Keys);
try
sortedDictKeys.Sort; //default ascending
for i in sortedDictKeys do
log.Lines.Add(Format('%d, %s', [i, dict.Items[i]]));
finally
sortedDictKeys.Free;
end;
//sort by keys descending
log.Lines.Add('KEYS SORTED DESCENDING:');
sortedDictKeys := TList<Integer>.Create(dict.Keys);
try
sortedDictKeys.Sort(TComparer<Integer>.Construct(
function (const L, R: integer): integer
begin
result := R - L;
end
)) ;
for i in sortedDictKeys do
log.Lines.Add(Format('%d, %s', [i, dict.Items[i]]));
finally
sortedDictKeys.Free;
end;
finally
dict.Free;
end;
end;