1泛型的相关介绍
通过泛型,可以创建一个类,使其自动处理不同类型的数据。
可以通过使用object类型的引用来创建通用的类、接口、方法和委托。但这种方法的缺陷在于,无法保证类型安全。
泛型弥补了无法保证类型安全的缺陷,也简化了处理的过程。因为不再需要执行object与实际操作的数据类型之间的转换。
相关链接:http://hi.baidu.com/bradydreamer/item/2867591ea83d4324f6625c65
2.泛型的约束 相关链接:http://blog.csdn.net/phoenix_17th/article/details/6089489
1.接口约束。
例如,可以声明一个泛型类 MyGenericClass,这样,类型参数T 就可以实现 IComparable<T> 接口:
2.基类约束:指出某个类型必须将指定的类作为基类(或者就是该类本身),才能用作该泛型类型的类型参数。
这样的约束一经使用,就必须出现在该类型参数的所有其他约束之前。
where T : class
where U : struct
{
}
3.where 子句还可以包括构造函数约束。
可以使用 new 运算符创建类型参数的实例;但类型参数为此必须受构造函数约束 new() 的约束。new() 约束可以让编译器知道:提供的任何类型参数都必须具有可访问的无参数(或默认)构造函数。例如:
{
// The following line is not possible without new() constraint:
T item = new T();
}
new() 约束出现在 where 子句的最后。
4.对于多个类型参数,每个类型参数都使用一个 where 子句,
例如:
class Dictionary < TKey,TVal >
where TKey: IComparable, IEnumerable
where TVal: MyI
{
public void Add(TKey key, TVal val)
{
}
}
5.还可以将约束附加到泛型方法的类型参数,例如:
请注意,对于委托和方法两者来说,描述类型参数约束的语法是一样的:
3.泛型类与泛型方法的实现
class myclass<T> where T : class
{
public myclass() { }
public string getStr(T _instance) {
return _instance.ToString();
}
}
class myclass2
{
public string getStr<T>(T _t) {
return _t.ToString();
}
}
调用:
String input="123";
String getStr = new myclass<String>().getStr(input);
string getStr2 = new myclass2().getStr<String>(input);