C# 泛型类概念与实例的理解应用浅析

开发 后端
C# 泛型类封装不是特定于具体数据类型的操作。C# 泛型类最常用于集合,如链接列表、哈希表、堆栈、队列、树等。那么本文就向你详细介绍C# 泛型类的内容。

C# 泛型类封装不是特定于具体数据类型的操作。泛型类最常用于集合,如链接列表、哈希表、堆栈、队列、树等,其中,像从集合中添加和移除项这样的操作都以大体上相同的方式执行,与所存储数据的类型无关。对于大多数需要集合类的方案,推荐的方法是使用 .NET Framework 2.0 类库中所提供的类。一般情况下,创建泛型类的过程为:从一个现有的具体类开始,逐一将每个类型更改为类型参数,直至达到通用化和可用性的***平衡。创建您自己的泛型类时,需要特别注意以下事项:

将哪些类型通用化为类型参数。一般规则是,能够参数化的类型越多,代码就会变得越灵活,重用性就越好。但是,太多的通用化会使其他开发人员难以阅读或理解代码。如果存在约束,应对类型参数应用什么约束。一个有用的规则是,应用尽可能最多的约束,但仍使您能够处理需要处理的类型。例如,如果您知道您的泛型类仅用于引用类型,则应用类约束。这可以防止您的类被意外地用于值类型,并允许您对 T 使用 as 运算符以及检查空值。 是否将泛型行为分解为基类和子类。由于泛型类可以作为基类使用,此处适用的设计注意事项与非泛型类相同。有关从泛型基类继承的规则,请参见下面的内容。是否实现一个或多个泛型接口。

例如,如果您设计一个类,该类将用于创建基于泛型的集合中的项,则可能需要实现一个接口,如 IComparable<T>,其中 T 是您的类的类型。

类型参数和约束的规则对于泛型类行为有几方面的含义,特别是关于继承和成员可访问性。请务必先理解一些术语,然后再继续进行。对于泛型类 Node<T>,,客户端代码可以通过指定类型参数引用该类,以创建封闭式构造类型 (Node<int>),或者可以让类型参数处于未指定状态(例如在指定泛型基类时)以创建开放式构造类型 (Node<T>)。泛型类可以从具体的、封闭式构造或开放式构造基类继承:

C# 泛型类代码

  1. class BaseNode { }  
  2. class BaseNodeGeneric<T> { }  
  3.  
  4. // concrete type  
  5. class NodeConcrete<T> : BaseNode { }  
  6.  
  7. //closed constructed type  
  8. class NodeClosed<T> : BaseNodeGeneric<int> { }  
  9.  
  10. //open constructed type   
  11. class NodeOpen<T> : BaseNodeGeneric<T> { } 

非泛型(具体)类可以从封闭式构造基类继承,但无法从开放式构造类或裸类型参数继承,因为在运行时客户端代码无法提供实例化基类所需的类型变量。

C# 泛型类代码

  1. //No error  
  2. class Node1 : BaseNodeGeneric<int> { }  
  3.  
  4. //Generates an error  
  5. //class Node2 : BaseNodeGeneric<T> {}  
  6.  
  7. //Generates an error  
  8. //class Node3 : T {} 

从开放式构造类型继承的泛型类必须为任何未被继承类共享的基类类型参数提供类型变量,如以下代码所示:

C# 泛型类代码

  1. class BaseNodeMultiple<T, U> { }  
  2.  
  3. //No error  
  4. class Node4<T> : BaseNodeMultiple<T, int> { }  
  5.  
  6. //No error  
  7. class Node5<T, U> : BaseNodeMultiple<T, U> { }  
  8.  
  9. //Generates an error  
  10. //class Node6<T> : BaseNodeMultiple<T, U> {}  

从开放式构造类型继承的泛型类必须指定约束,这些约束是基类型约束的超集或暗示基类型约束:

C# 泛型类代码

  1. class NodeItem<T> where T : System.IComparable<T>, new() { }  
  2. class SpecialNodeItem<T> :   
  3. NodeItem<T> where T : System.IComparable<T>, new() { } 

泛型类型可以使用多个类型参数和约束,如下所示:

C# 泛型类代码

  1. class SuperKeyType<K, V, U>  
  2.     where U : System.IComparable<U>  
  3.     where V : new()  
  4. { } 

开放式构造类型和封闭式构造类型可以用作方法参数:

C# 泛型类代码

  1. void Swap<T>(List<T> list1, List<T> list2)  
  2. {  
  3.     //code to swap items  
  4. }  
  5.  
  6. void Swap(List<int> list1, List<int> list2)  
  7. {  
  8.     //code to swap items  

泛型类是不变的。也就是说,如果输入参数指定 List<BaseClass>,则当您试图提供 List<DerivedClass> 时,将会发生编译时错误。

C# 泛型类的相关内容就向你介绍到这里,希望对你了解和学习C# 泛型类有所帮助。

【编辑推荐】

  1. C# 泛型应用及优点浅析
  2. 浅析C# 泛型约束中的一般约束
  3. C# 泛型约束之派生约束浅析
  4. 浅析C# 泛型约束中的构造函数约束
  5. C# 强制类型转换与C# 泛型浅析
责任编辑:仲衡 来源: MSDN
相关推荐

2009-08-24 17:58:19

C# 泛型集合

2009-08-24 10:37:27

C# 泛型

2009-08-24 17:39:21

C# 泛型集合

2009-08-24 10:29:39

C# 泛型

2009-08-24 15:12:13

C# 泛型接口

2009-08-24 15:28:19

C# 泛型方法

2009-08-24 16:39:19

C# 泛型应用

2009-08-24 17:27:05

C#泛型应用

2009-08-24 11:35:20

C# 泛型应用

2009-08-24 14:20:13

C# 强制类型转换

2009-08-24 14:51:25

C# 泛型泛型类型

2009-08-24 18:15:24

C# Dictiona

2009-08-24 10:07:57

C#泛型处理

2009-08-24 15:50:23

C# 泛型C# 泛型委托

2009-08-27 17:11:44

C# Fluent I

2009-08-24 16:01:44

C# 泛型

2009-08-17 17:49:20

C# 枚举

2009-08-24 18:22:05

C# 泛型编程

2009-08-24 13:31:38

C# 泛型约束

2009-09-02 18:03:19

C#实现泛型类
点赞
收藏

51CTO技术栈公众号