关于泛型类和扩展方法的一点思考

 

我们经常通过泛型构造函数创建泛型实例,也常调用实例的扩展方法。以下的代码在项目中随处可见:

 

        static void Main(string[] args)
        {
            var strs = new List<string> {"hello","world"};
            var result = strs.Where(s => s.StartsWith("h"));
            foreach (var item in result)
            {
                Console.WriteLine(item);
            }
            Console.ReadKey();
        }

 

以上,

 

● 通过泛型集合List<T>的构造函数创建了实例,内部是如何实现的呢?

 

● 对实例变量strs采用Where方法,我们发现Where也足够”聪明”,因为它是针对IEnumerable集合类型的扩展方法。

 

.NET内部到底是如何实现的呢?不妨临摹一下~~

 

创建一个类型泛型。

 

    public class MyCute<T>
    {
        public MyCute(T t)
        {
            GetCute = t;
        }
        public T GetCute { get; set; }
    }    

 

在客户端这样调用:

 

        static void Main(string[] args)
        {
            var cuteInt = new MyCute<int>(10);
            var cuteStr = new MyCute<string>("hello");
            Console.WriteLine(cuteInt.GetCute);
            Console.WriteLine(cuteStr.GetCute);
            Console.ReadKey();
        }

 

以上,或许得到的启示是:如果想通过构造函数创建泛型实例,需要定义一个泛型类,一个泛型类型的属性,一个把泛型类型作为参数的构造方法。

 

现在想对泛型实例cuteInt和cuteStr的属性GetCute使用扩展方法,如何做呢?

 

cuteInt的属性GetCute是int类型,cuteStr的属性GetCute是string类型,两者的共同基类是object,那就针对object类型写一个扩展方法。

 

    public static class MyHelper
    {
        public static string GetStr(this object obj)
        {
            return obj.ToString() + "--added string";
        }
    }

 

客户端变成这样:

 

        static void Main(string[] args)
        {
            var cuteInt = new MyCute<int>(10);
            var cuteStr = new MyCute<string>("hello");
            Console.WriteLine(cuteInt.GetCute.GetStr());
            Console.WriteLine(cuteStr.GetCute.GetStr());
            Console.ReadKey();
        }    

 

总结:

 

● 如果针对不同类型的操作逻辑是一样的,就可以抽象出一个泛型类。泛型类和普通类没有本质的区别,只不过在类名称后面多了一个占位符、或者叫类型参数,泛型类的构造函数参数是类型参数,泛型类的属性类型也是类型参数。

 

● 如果针对不同类型实例的操作逻辑是一样的,就可以针对不同实例类型的共同父类或接口写一个扩展方法。

posted @ 2015-04-24 10:54  Darren Ji  阅读(615)  评论(2编辑  收藏  举报

我的公众号:新语新世界,欢迎关注。