我们经常通过泛型构造函数创建泛型实例,也常调用实例的扩展方法。以下的代码在项目中随处可见:
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();
}
总结:
- 如果针对不同类型的操作逻辑是一样的,就可以抽象出一个泛型类。泛型类和普通类没有本质的区别,只不过在类名称后面多了一个占位符、或者叫类型参数,泛型类的构造函数参数是类型参数,泛型类的属性类型也是类型参数。
- 如果针对不同类型实例的操作逻辑是一样的,就可以针对不同实例类型的共同父类或接口写一个扩展方法。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对编程网的支持。如果你想了解更多相关内容请查看下面相关链接