游戏人生
首页
(current)
GameDevTools
登陆
|
注册
个人中心
注销
C# 基础教程
C# 教程
C# 简介
C# 与.net
C# 开发工具
C# 程序结构
C# 基本语法
C# 数据类型
C# 类型转换
C# 变量
C# 常量
C# 运算符
C# 判断
C# 循环
C# 封装
C# 方法
C# 可空类型(Nullable)
C# 数组(Array)
C# 字符串(string)
C# 结构体(Struct)
C# 枚举(Enum)
C# 类(Class)
C# 继承
C# 多态
C# 运算符重载
C# 接口(Interface)
C# 命名空间(Namespace)
C# 预处理器指令
C# 正则表达式
C# 异常处理
C# 文件的输入与输出
C# 高级教程
C# 特性(Attribute)
C# 反射(Reflection)
C# 属性(Property)
C# 索引器(Indexer)
C# 委托(Delegate)
C# 事件(Event)
C# 集合(Collection)
C# 泛型(Generic)
C# 匿名方法
C# 不安全代码
C# 多线程
C# 实例
C# 正则表达式实例(1)-fprintf立即刷新
<< C# 集合(Collection)
C# 匿名方法 >>
C# 泛型(Generic)
泛型类似于模板。 写好一个模板后,在编写代码时,替换掉这个模板中的某些字母,就得到了一段新的代码。 下面这个例子可以很直观的展示出泛型的特性: ```csharp using System; using System.Collections.Generic; namespace GenericApplication { public class MyGenericArray<T> { private T[] array; public MyGenericArray(int size) { array = new T[size + 1]; } public T getItem(int index) { return array[index]; } public void setItem(int index, T value) { array[index] = value; } } class Tester { static void Main(string[] args) { // 声明一个整型数组 MyGenericArray<int> intArray = new MyGenericArray<int>(5); // 设置值 for (int c = 0; c < 5; c++) { intArray.setItem(c, c*5); } // 获取值 for (int c = 0; c < 5; c++) { Console.Write(intArray.getItem(c) + " "); } Console.WriteLine(); // 声明一个字符数组 MyGenericArray<char> charArray = new MyGenericArray<char>(5); // 设置值 for (int c = 0; c < 5; c++) { charArray.setItem(c, (char)(c+97)); } // 获取值 for (int c = 0; c < 5; c++) { Console.Write(charArray.getItem(c) + " "); } Console.WriteLine(); Console.ReadKey(); } } } ``` 当上面的代码被编译和执行时,它会产生下列结果: 0 5 10 15 20 a b c d e ------------ #### 泛型(Generic)的特性 使用泛型是一种增强程序功能的技术,具体表现在以下几个方面: - 它有助于您最大限度地重用代码、保护类型的安全以及提高性能。 - 您可以创建泛型集合类。.NET 框架类库在 System.Collections.Generic 命名空间中包含了一些新的泛型集合类。您可以使用这些泛型集合类来替代 System.Collections 中的集合类。 - 您可以创建自己的泛型接口、泛型类、泛型方法、泛型事件和泛型委托。 - 您可以对泛型类进行约束以访问特定数据类型的方法。 - 关于泛型数据类型中使用的类型的信息可在运行时通过使用反射获取。 ------------ #### 泛型(Generic)方法 在上面的实例中,我们已经使用了泛型类,我们可以通过类型参数声明泛型方法。下面的程序说明了这个概念: ```csharp 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 ------------ #### 泛型(Generic)委托 您可以通过类型参数定义泛型委托。例如: delegate T NumberChanger<T>(T n); 下面的实例演示了委托的使用: ```csharp 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
<< C# 集合(Collection)
C# 匿名方法 >>
提交
5e32d9b9498b3f00945f8a00