注意:属性和索引器不能指定自己的泛型参数,它们只能使用所属类中定义的泛型参数进行操作。
在调用泛型方法的时候,你可以提供要在调用场所使用的类型,如下所示:
MyClass myClass = new MyClass();
myClass.MyMethod<int>(3);
//泛型推理机制调用泛型方法
MyClass myClass = new MyClass();
myClass.MyMethod(3);
注意:泛型方法无法只根据返回值的类型推断出类型,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
public GenericMethodDemo() { MyClass myClass = new MyClass(); /**************************************************** 无法从用法中推理出方法“GenericMethodDemo.MyClass.MyMethod<T>()”的类型参数。 请尝试显式指定类型参数。 ***************************************************/ int number = myClass.MyMethod(); } public class MyClass { public T MyMethod<T>() { // } } |
泛型方法中泛型参数的约束,如下:
1
2
3
4
5
6
7
8
|
public class MyClass { public void MyMethod<X>(X x) where X:IComparable<X> { // } } |
.NET泛型约束
如果客户端代码尝试使用某个约束所不允许的类型来实例化类,则会产生编译时错误。这些限制称为约束。约束是使用 where 上下文关键字指定的。
下表列出了五种类型的约束:
约束 | 说明 |
---|---|
T:struct |
类型参数必须是值类型。可以指定除 Nullable 以外的任何值类型。 |
T:class |
类型参数必须是引用类型,包括任何类、接口、委托或数组类型。 |
T:new() |
类型参数必须具有无参数的公共构造函数。当与其他约束一起使用时,new() 约束必须最后指定。 |
T:<基类名> |
类型参数必须是指定的基类或派生自指定的基类。 |
T:<接口名称> |
类型参数必须是指定的接口或实现指定的接口。可以指定多个接口约束。约束接口也可以是泛型的。 |
T:U |
为 T 提供的类型参数必须是为 U 提供的参数或派生自为 U 提供的参数。这称为裸类型约束.
|
派生约束
1.常见的
public class MyClass5 where T :IComparable { }
2.约束放在类的实际派生之后
public class B { }
public class MyClass6 : B where T : IComparable { }
3.可以继承一个基类和多个接口,且基类在接口前面
public class B { }
public class MyClass7 where T : B, IComparable, ICloneable { }