📄 slist.pas
字号:
unit SList;
interface
uses
Classes;
type
TSafeList = class
private
LType: TClass;
FList: TList;
function Get (Index: Integer): TObject;
procedure Put (Index: Integer; Item: TObject);
function GetCount: Integer;
public
constructor Create (CType: TClass);
destructor Destroy; override;
function Add (Item: TObject): Integer;
function Equals(List: TSafeList): Boolean;
property Count: Integer read GetCount;
property Items [Index: Integer]: TObject
read Get write Put; default;
end;
implementation
uses
SysUtils;
constructor TSafeList.Create (CType: TClass);
begin
FList := TList.Create;
LType := CType;
end;
destructor TSafeList.Destroy;
begin
FList.Free;
inherited Destroy;
end;
function TSafeList.Get(Index: Integer): TObject;
begin
Result := FList [Index];
end;
function TSafeList.Add (Item: TObject): Integer;
var
Test: Boolean;
begin
try
Test := Item is LType;
except
on Exception do
raise EInvalidCast.Create (Format (
'SafeList: Cannot add a non-object to a list of %s objects',
[LType.ClassName]));
end;
if Test then
Result := FList.Add (Item)
else
raise EInvalidCast.Create (Format (
'SafeList: Cannot add a %s object to a list of %s objects',
[Item.ClassName, LType.ClassName]));
end;
procedure TSafeList.Put(Index: Integer; Item: TObject);
var
Test: Boolean;
begin
try
Test := Item is LType;
except on Exception do
raise EInvalidCast.Create (Format (
'SafeList: Cannot put a non-object into a list of %s objects',
[LType.ClassName]));
end;
if Test then
FList [Index] := Item
else
raise EInvalidCast.Create (Format (
'SafeList: Cannot put a %s object into a list of %s objects',
[TObject(Item).ClassName, LType.ClassName]));
end;
function TSafeList.GetCount: Integer;
begin
Result := FList.Count;
end;
function TSafeList.Equals(List: TSafeList): Boolean;
var
I: Integer;
begin
Result := False;
if List.Count <> FList.Count then
Exit;
for I := 0 to List.Count - 1 do
if List[I] <> FList[I] then
Exit;
Result := True;
end;
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -