泛型类和泛型方法的简单实现

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> 接口:

public class MyGenericClass < T > where T:IComparable { }


2.基类约束:指出某个类型必须将指定的类作为基类(或者就是该类本身),才能用作该泛型类型的类型参数。
这样的约束一经使用,就必须出现在该类型参数的所有其他约束之前。

class MyClassy < T, U >
where T :
class
where U :
struct
{
}


3.where 子句还可以包括构造函数约束。
可以使用 new 运算符创建类型参数的实例;但类型参数为此必须受构造函数约束 new() 的约束。new() 约束可以让编译器知道:提供的任何类型参数都必须具有可访问的无参数(或默认)构造函数。例如:

public class MyGenericClass < T > where T: IComparable, new ()
{
// The following line is not possible without new() constraint:
         T item = new T();
}

new() 约束出现在 where 子句的最后。

4.对于多个类型参数,每个类型参数都使用一个 where 子句,
例如:

interface MyI { }
class Dictionary < TKey,TVal >
where TKey: IComparable, IEnumerable
where TVal: MyI
{
public void Add(TKey key, TVal val)
{
}
}


5.还可以将约束附加到泛型方法的类型参数,例如:

public bool MyMethod < T > (T t) where T : IMyInterface { }


请注意,对于委托和方法两者来说,描述类型参数约束的语法是一样的:

delegate T MyDelegate < T > () where T : new ()

 

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);


 


  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值