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

在一个基本数据类型的方法中求解最大值或者最小值是一件很方便,同时也是很简单的事。但是如果你想复用这个方法,我们就需要使用到泛型编程的概念了。这就好比是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#泛型编程更加完善,实现了代码一次编写的良好的复用效果!

你可能感兴趣的:(泛型,C#,泛型编程)