Delphi:泛型后代的泛型列表并以泛型作为参数

2024-01-11

我对泛型的理解以及它们如何使用和不可以使用有些困难。

我有一个像这样的通用类 TControlMediator:

TControlMediator<C, T> = class
private
  FMediatedComponent: C;
public
  constructor Create(ComponentToMediate: C);

  function GetValue: T; virtual; abstract;
  procedure SetValue(Value: T); virtual; abstract;

  property MediatedControl: C read FMediatedComponent;
end;

然后,我为我想要调解的每个控件类型创建“具体”子类:

TEditMediator = class(TControlMediator<TEdit, string>)
public
  function GetValue: string; override;
  procedure SetValue(Value: string); override;
end;

到目前为止,一切似乎都正常。但是,当我想要 TControlMediator 后代的列表,或者将 TControlMediator 作为方法的参数时,就会出现问题:

TViewMediator = class
private
  FControlMediators: TList<TControlMEdiator<C, T>>;
public
  procedure registerMediator(AControlMediator: TControlMediator<C, T>);
  procedure unregisterMediator(AControlMediator: TControlMediator<C, T>);
end;

编译器因致命错误而停止:

[DCC Error] mediator.pas(23): E2003 Undeclared identifier: 'C'
[DCC Error] mediator.pas(28): E2007 Constant or type identifier expected

有人知道这应该如何完成吗?


Delphi 的泛型类型没有协变或逆变。您的泛型类型必须使用实际类型作为参数。换句话说,这个:

TViewMediator = class
private
  FControlMediators: TList<TControlMEdiator<C, T>>;
public
  procedure registerMediator(AControlMediator: TControlMediator<C, T>);
  procedure unregisterMediator(AControlMediator: TControlMediator<C, T>);
end;

...不起作用,因为 C 和 T 不是泛型类型参数TViewMediator或实际类型。

TControlMediator<TEdit, string>是一种类型。TList<TControlMEdiator<C, T>>,当没有类型时C or T在范围内不是类型。您不能在实例化泛型类型的除非这些占位符在范围内作为包含泛型类型或方法的泛型参数。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Delphi:泛型后代的泛型列表并以泛型作为参数 的相关文章

随机推荐