基于泛型参数类型的类型推断(Delphi)

前端之家收集整理的这篇文章主要介绍了基于泛型参数类型的类型推断(Delphi)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试编写一个接受匹配参数类型的泛型函数.
Delphi确实在普通参数的简单情况下正确地推断出类型参数.

例如:

type
  TFoo = class
    function Pair<T>(e1,e2: T): TList<T>;
  end;

用aFoo.Pair(1,2)调用它;工作得很好,但是当我将参数签名更改为泛型类型时

type
  TFoo = class
    function InsertInto<T>(aList: TList<T>; aVal: T): TList<T>;
  end;

并试着打电话给它
aFoo.InsertInto(TList< String> .Create,’bar’);

然后编译器抱怨它:
E2010不兼容的类型:’Generics.Collections.TList< uTest.TFoo.InsertInto.T>‘和’Generics.Collections.TList< System.String>‘

有什么方法可以编写这个(或类似的)方法,以便客户端不必指定类型参数?
aFoo.InsertInto< String>(TList< String> .Create,’bar’);

解决方法

我的猜测是来自Delphi的强类型性质.
uTest.TFoo.InsertInto.T等同于System.String,但它实际上是一个不同的类型.

就像在这个例子中Int1和Int2不是同一类型一样:

var
  Int1: array[1..10] of Integer;
  Int2: array[1..10] of Integer;
      ...
  Int1 := Int2; // <== BOOM! E2008 Incompatible types (in XE2)

实际问题不是类型推断,而是根据Pascal / Delphi的严格规则,类型不兼容.

猜你在找的Delphi相关文章