泛型类定义 小小练习

 不需要引用其他单元文件,

如果用泛型列表TList<T>或 字典TDictionary<TKey,TValue>时需要引用:System.Generics.Collections

unit Unit1;

interface
uses System.Classes;
type
  A = class //一般类
  end;
  B = class(A) //一般继承
  end;
  GB<T> = class(A) //继承于A的泛型类
  end;
  GC =class(GB<string>)//继承于GB<T>并指定T为 string的类  //值类型
  end;
  GD =class(GB<TStringList>)//继承于GB<T>并指定T为 TStringList的类  //引用类型
  end;
  GE=class(GB<A>)  //继承于GB<T>并指定T为 A的类 ;是自己的祖先类也可以吗?
  end;
  //-------------
  GH<T:A, constructor> =class  //一个直接的泛型类 T限定为A类 或A的子类
  end;
  J =class(GH<A>)
  end;
  k =class(GH<B>)
  end;
//  L =class(GH<Int>) //会出错,因为 GH的类型限定 A或A的子类
//  end;
  //----------------
  HttpAdpter =class
    procedure HTTPGetSync<T>(httpName: string); //泛型方法不一定写在泛型类里面
  end;
implementation

{ HttpAdpter }

procedure HttpAdpter.HTTPGetSync<T>(httpName: string);
begin
//方法体里面用到T,这里有疑问 ??  这个T应该从哪里传进去??
end;

end.

 =========================

unit System.SysUtils; //单元中有定义下面的泛型方法 类型
// Generic Anonymous method declarations
type
  TProc = reference to procedure;
  TProc<T> = reference to procedure (Arg1: T);
  TProc<T1,T2> = reference to procedure (Arg1: T1; Arg2: T2);

  //----------以下应用 :用到两个 占位符,
class procedure RunOnUIThread<T1, T2>(proc: TProc<T1, T2>; arg1: T1;
      arg2: T2); overload;
      
class procedure TTask.RunOnUIThread<T1, T2>(proc: TProc<T1, T2>; arg1: T1;
arg2: T2);
begin
  Synchronize(TThread.CurrentThread,
    procedure()
    begin
      proc(arg1, arg2);
    end);
end;

 上面用到两个 占位符,通过 RunOnUIThread<T1,T2>()参数传进去,并且前面要标明用到的 占位符,

 这个方法有点特殊,传了一个方法 proc: TProc<T1, T2> 进去

posted @ 2017-03-17 16:43  海蓝7  阅读(228)  评论(0编辑  收藏  举报