泛型(Generic)的特性
使用泛型是一种增强程序功能的技术,具体表现在以下几个方面:
- 它有助于您最大限度地重用代码、保护类型的安全以及提高性能。
- 您可以创建泛型集合类。.NET 框架类库在 System.Collections.Generic 命名空间中包含了一些新的泛型集合类。您可以使用这些泛型集合类来替代 System.Collections 中的集合类。
- 您可以创建自己的泛型接口、泛型类、泛型方法、泛型事件和泛型委托。
- 您可以对泛型类进行约束以访问特定数据类型的方法。
- 关于泛型数据类型中使用的类型的信息可在运行时通过使用反射获取。
泛型类:
1 using System; 2 using System.Collections.Generic; 3 4 namespace GenericApplication 5 { 6 public class MyGenericArray<T> 7 { 8 private T[] array; 9 public MyGenericArray(int size) 10 { 11 array = new T[size + 1]; 12 } 13 public T getItem(int index) 14 { 15 return array[index]; 16 } 17 public void setItem(int index, T value) 18 { 19 array[index] = value; 20 } 21 } 22 23 class Tester 24 { 25 static void Main(string[] args) 26 { 27 // 声明一个整型数组 28 MyGenericArray<int> intArray = new MyGenericArray<int>(5); 29 // 设置值 30 for (int c = 0; c < 5; c++) 31 { 32 intArray.setItem(c, c*5); 33 } 34 // 获取值 35 for (int c = 0; c < 5; c++) 36 { 37 Console.Write(intArray.getItem(c) + " "); 38 } 39 Console.WriteLine(); 40 // 声明一个字符数组 41 MyGenericArray<char> charArray = new MyGenericArray<char>(5); 42 // 设置值 43 for (int c = 0; c < 5; c++) 44 { 45 charArray.setItem(c, (char)(c+97)); 46 } 47 // 获取值 48 for (int c = 0; c < 5; c++) 49 { 50 Console.Write(charArray.getItem(c) + " "); 51 } 52 Console.WriteLine(); 53 Console.ReadKey(); 54 } 55 } 56 }
当上面的代码被编译和执行时,它会产生下列结果:
0 5 10 15 20 a b c d e
泛型方法:
using System; using System.Collections.Generic; namespace GenericMethodAppl { class Program { static void Swap<T>(ref T lhs, ref T rhs) { T temp; temp = lhs; lhs = rhs; rhs = temp; } static void Main(string[] args) { int a, b; char c, d; a = 10; b = 20; c = 'I'; d = 'V'; // 在交换之前显示值 Console.WriteLine("Int values before calling swap:"); Console.WriteLine("a = {0}, b = {1}", a, b); Console.WriteLine("Char values before calling swap:"); Console.WriteLine("c = {0}, d = {1}", c, d); // 调用 swap Swap<int>(ref a, ref b); Swap<char>(ref c, ref d); // 在交换之后显示值 Console.WriteLine("Int values after calling swap:"); Console.WriteLine("a = {0}, b = {1}", a, b); Console.WriteLine("Char values after calling swap:"); Console.WriteLine("c = {0}, d = {1}", c, d); Console.ReadKey(); } } }
当上面的代码被编译和执行时,它会产生下列结果:
Int values before calling swap:
a = 10, b = 20 Char values before calling swap: c = I, d = V Int values after calling swap: a = 20, b = 10 Char values after calling swap: c = V, d = I
public static int Find<T>(T[] items, T item) //创建泛型方法
1. 创建一个公共的、静态的泛型方法;
2. int Find:方法的返回类型是整型;
3. <T>: 方法的类型参数是T(泛型);
4. (T[] items, T item) : 第一个参数T[] items表示是T类型的数组,数组中的每个元素都是T,第二个参数item类型是T ;
抽象abstract, interface,
1. 接口本身不能被实例化,可以指向派生子类的实例;
2. 泛型方法可以在非泛型类中实现;
泛型(Generic)委托
您可以通过类型参数定义泛型委托。例如:
delegate T NumberChanger<T>(T n);
下面的实例演示了委托的使用:
泛型(Generic)委托 您可以通过类型参数定义泛型委托。例如: delegate T NumberChanger<T>(T n); 下面的实例演示了委托的使用: using System; using System.Collections.Generic; delegate T NumberChanger<T>(T n); namespace GenericDelegateAppl { class TestDelegate { static int num = 10; public static int AddNum(int p) { num += p; return num; } public static int MultNum(int q) { num *= q; return num; } public static int getNum() { return num; } static void Main(string[] args) { // 创建委托实例 NumberChanger<int> nc1 = new NumberChanger<int>(AddNum); NumberChanger<int> nc2 = new NumberChanger<int>(MultNum); // 使用委托对象调用方法 nc1(25); Console.WriteLine("Value of Num: {0}", getNum()); nc2(5); Console.WriteLine("Value of Num: {0}", getNum()); Console.ReadKey(); } } } 当上面的代码被编译和执行时,它会产生下列结果: Value of Num: 35 Value of Num: 175
当上面的代码被编译和执行时,它会产生下列结果:
Value of Num: 35 Value of Num: 175