C#中的泛型化方法的实现

时间:2022-11-16 10:15:13

在一个基本数据类型的方法中求解最大值或者最小值是一件很方便,同时也是很简单的事。但是如果你想复用这个方法,我们就需要使用到泛型编程的概念了。这就好比是C++中的模板函数,或者java中的泛型操作。相比而言。C#的语法和Java的语法表现出了惊人的一致。
下面我们先看一个简单的例子吧


 public static object getMinValue(object[] array)
{
IComparable min = (IComparable)array[0];
foreach(object i in array){
if (((IComparable)i).CompareTo(min)<0)
{
min = (IComparable)i;
}
}
return min;
}

注意:这里使用了static来修饰该方法,是因为我直接在static void Main()方法中调用了这个方法,所以才加的这个关键字。


但是这样做看似合理也正确,却会报出类型转换错误的异常。所以这仍然是行不通的。我们需要借助于where T :约束条件来进行处理
所以修改成如下代码:

 public static  T getMinValue<T>(T[] array) where T: IComparable<T>
{
T min = array[0];
foreach(T i in array){
if ((i).CompareTo(min)<0)
{
min = i;
}
}
return min;
}

好了,这次在运行程序。就不会报出错误了。


总结:
IComparable接口定义了一个CompareTo的方法,这样就可以让object类型的值进行比较了。
优点:使得C#泛型编程更加完善,实现了代码一次编写的良好的复用效果!