浅析C#泛型约束中的一般约束

C# 泛型约束中的一般约束使用 C# 泛型,编译器会将一般代码编译为 IL,而不管客户端将使用什么样的类型实参。因此,一般代码可以尝试使用与客户端使用的特定类型实参不兼容的一般类型参数的方法、属性或成员。这是不可接受的,因为它相当于缺少类型安全。在 C# 中,您需要通知编译器客户端指定的类型必须遵守哪些约束,以便使它们能够取代一般类型参数而得到使用。存在三个类型的约束。派生约束指示编译器一般类型参数派生自诸如接口或特定基类之类的基类型。默认构造函数约束指示编译器一般类型参数公开了默认的公共构造函数(不带任何参数的公共构造函数)。引用/值类型约束将一般类型参数约束为引用类型或值类型。一般类型可以利用多个约束,您甚至可以在使用一般类型参数时使 IntelliSense 反射这些约束,例如,建议基类型中的方法或成员。

创新互联公司是一家专注于成都做网站、网站制作、成都外贸网站建设与策划设计,赫山网站建设哪家好?创新互联公司做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:赫山等地区。赫山做网站价格咨询:13518219792

需要注意的是,尽管C# 泛型约束是可选的,但它们在开发一般类型时通常是必不可少的。没有它们,编译器将采取更为保守的类型安全方法,并且只允许在一般类型参数中访问 Object 级别功能。约束是一般类型元数据的一部分,以便客户端编译器也可以利用它们。客户端编译器只允许客户端开发人员使用遵守这些约束的类型,从而实施类型安全。

C# 泛型约束中的一般约束应用实例:

以下示例将详细说明C# 泛型约束的需要和用法。假设您要链表中添加索引功能或按键搜索功能

 
 
 
  1. public class LinkedList  
  2. {  
  3.    T Find(K key)  
  4.    {...}  
  5.    public T this[K key]  
  6.    {  
  7.       get{return Find(key);}  
  8.    }  

这使客户端可以编写以下代码:

 
 
 
  1. LinkedList list = new LinkedList();  
  2.  
  3. list.AddHead(123,"AAA");  
  4. list.AddHead(456,"BBB");  
  5. string item = list[456];  
  6. Debug.Assert(item == "BBB"); 

要实现搜索,您需要扫描列表,将每个节点的键与您要查找的键进行比较,并且返回键匹配的节点的项。问题在于,Find() 的以下实现无法编译:

 
 
 
  1. T Find(K key)  
  2. {  
  3.    Node current = m_Head;  
  4.    while(current.NextNode != null)  
  5.    {  
  6.       if(current.Key == key) //Will not compile  
  7.          break;  
  8.       else 
  9.            
  10.          current = current.NextNode;  
  11.    }  
  12.    return current.Item;   

原因在于,编译器将拒绝编译以下行:

 
 
 
  1. if(current.Key == key) 

上述行将无法编译,因为编译器不知道 K(或客户端提供的实际类型)是否支持 == 运算符。例如,默认情况下,结构不提供这样的实现。您可以尝试通过使用 IComparable 接口来克服 == 运算符局限性:

 
 
 
  1. public interface IComparable   
  2. {  
  3.    int CompareTo(object obj);  

如果您与之进行比较的对象等于实现该接口的对象,则 CompareTo() 返回 0;因此,Find() 方法可以按如下方式使用它:

 
 
 
  1. if(current.Key.CompareTo(key) == 0) 

遗憾的是,这也无法编译,因为编译器无法知道 K(或客户端提供的实际类型)是否派生自 IComparable。

您可以显式强制转换到 IComparable,以强迫编译器编译比较行,除非这样做需要牺牲类型安全:

 
 
 
  1. if(((IComparable)(current.Key)).CompareTo(key) == 0) 

如果客户端使用的类型不是派生自 IComparable,则会导致运行时异常。此外,当所使用的键类型是值类型而非键类型参数时,您可以对该键执行装箱,而这可能具有一些性能方面的影响。

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

【编辑推荐】

  1. C#网络编程客户端程序设计浅析
  2. 浅析C# 泛型处理的问题空间
  3. C# 泛型概念的初步理解
  4. C# 泛型实现理解及实例浅析
  5. C# 泛型应用及优点浅析

当前名称:浅析C#泛型约束中的一般约束
文章地址:http://www.csdahua.cn/qtweb/news28/262628.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网