如何使用泛型达到代码重用的目的

通过泛型,你重新获得了链接列表的代码通用(对于所有类型只用实现一次),而当你初始化链表的时候你告诉链表所能接受的类型。这个实现是非常简单的,让我们重新回到Node类:

创新互联建站服务项目包括云岩网站建设、云岩网站制作、云岩网页制作以及云岩网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,云岩网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到云岩省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

 
 
 
  1. public class Node{  
  2.     Object data;  
  3.     ... 

注意到 data 的类型是Object,(在EmployeeNode中,它是Employee)。我们将把它变成一个泛型(通常,由一个大写的T代表)。我们同样定义Node类,表示它可以被泛型化,以接受一个T类型。

 
 
 
  1. public class Node < T>{  
  2.     T data;  
  3.     ... 

读作:T类型的Node。T代表了当Node被初始化时,Node所接受的类型。T可以是Object,也可能是整型或者是Employee。这个在Node被初始化的时候才能确定。

注意:使用T作为标识只是一种约定俗成,你可以使用其他的字母组合来代替,比如这样:

 
 
 
  1. public class Node < UnknownType>{  
  2.     UnknownType data;  
  3.     ... 

通过使用T作为未知类型,next字段(下一个结点的引用)必须被声明为T类型的Node(意思是说接受一个T类型的泛型化Node)。

    Node< T> next;

构造函数接受一个T类型的简单参数:

 
 
 
  1. public Node(T data)  
  2. {  
  3.     this.data = data;  
  4.     this.next = null;  

Node 类的其余部分是很简单的,所有你需要使用Object的地方,你现在都需要使用T。LinkedList 类现在接受一个T类型的Node,而不是一个简单的Node作为头结点。

 
 
 
  1. public class LinkedList< T>{  
  2.     Node< T> headNode = null; 

再来一遍,转换是很直白的。任何地方你需要使用Object的,现在改做T,任何需要使用Node的地方,现在改做 Node< T>。下面的代码初始化了两个链接表。一个是整型的。

 
 
 
  1. LinkedList< int> ll = new LinkedList< int>(); 

另一个是Employee类型的:

 
 
 
  1. LinkedList< Employee> employees = new LinkedList< Employee>(); 

剩下的代码与***个版本没有区别,除了没有装箱、拆箱,而且也不可能将错误的类型保存到集合中。

 
 
 
  1. LinkedList< int> ll = new LinkedList< int>();  
  2. for ( int i = 0; i <  10; i ++ )  
  3. {  
  4.     ll.Add(i);  
  5. }  
  6.  
  7. Console.WriteLine(ll);  
  8. Console.WriteLine("  Done.");  
  9.  
  10. LinkedList< Employee> employees = new LinkedList< Employee>();  
  11. employees.Add(new Employee("John"));  
  12. employees.Add(new Employee("Paul"));  
  13. employees.Add(new Employee("George"));  
  14. employees.Add(new Employee("Ringo"));  
  15.  
  16. Console.WriteLine(employees);   
  17. Console.WriteLine("  Done.");  
  18. Console.WriteLine("The fourth integer is " + ll[3]);  
  19. Employee d = employees[1];  
  20. Console.WriteLine("The second Employee is " + d); 

泛型允许你不用复制/粘贴冗长的代码就实现类型安全的集合。而且,因为,使用泛型运行时才被扩展成特殊类型。Just In Time编译器可以在不同的实例之间共享代码,***,它显著地减少了你需要编写的代码。

这样,使用泛型就达到了代码重用的目的。

当前题目:如何使用泛型达到代码重用的目的
转载源于:http://www.shufengxianlan.com/qtweb/news13/530163.html

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

广告

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