C#泛型的简单讲解和应用.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C#泛型的简单讲解和应用.doc

泛型 什么是泛型 泛型是2.0版C#语言和公共语言运行库(CLR)中的一个新功能。泛型将类型参数的概念引入.NET Framework,类型参数使得 设计如下类和方法成为可能:这些类和方法将一个或多个类型的指定推迟到客户端代码声明并实例化该类或方法的时候。例如,通过使用泛 型类型参数T,您可以编写其他客户端代码能够使用的单个类,而不致引入运行时强制转换或装箱操作的成本或风险 为什么要使用泛型 我感觉泛型的最主要特点是减少了代码的重用性,保护了类型安全,减少了拆装箱的操作从而提高了性能 举例说明 我们在编写程序时,经常遇到两个模块的功能非常相似,只是一个是处理int数据,另一个是处理string数据,或者其他自定义的数据类型, 但我们没有办法,只能分别写多个方法处理每个数据类型,因为方法的参数类型不同。有没有一种办法,在方法屮传入通用的数据类型,这 样不就可以合并代码了吗?泛型的出现就是便可以轻松解决这个问题。 比如编写一个处理int类型的栈 public class Stack private int[] mitem; public int Pop() {???} public void Push(int item){???} publie Stack(int i) 上面代码运行的很好,但是,当我们需要一个栈来保存string类型时,该怎么办呢?很多人都会想到把上面的代码复制一份,把int改成 string不就行了。当然,这样做木身是没有任何问题的,但一个优秀的程序是不会这样做的,因为他想到若以后再需要long、Node类型 的栈该怎样做呢?还要再复制吗?优秀的程序员会想到用一个通用的数据类型object来实现这个栈: object类型通用的栈 2 2 3 4 5 6 7 8 9 10 1 public class Stack private object[] mitem; public object Pop() {???} public void Push (object item){???} public Stack(object i) { this.m iteni = new[i]; 这个栈写的不错,他非常灵活,可以接收任何数据类型,可以说是一劳永逸。但全面地讲,也不是没有缺陷的,主要表现在: 当Stack处理值类型时,会岀现装箱、折箱操作,这将在托管堆上分配和回收大量的变量,若数据量大,则性能损失非常严重。 在处理引用类型时,虽然没有装箱和折箱操作,但将用到数据类型的强制转换操作,增加处理器的负担。 在数据类型的强制转换上还有更严重的问题(假设stack是Stack的一个实例): Nodel x 二 new Nodel(); 2 stack. Push (x); 4 Node2 y = (Node2) stack. Pop (); 上面的代码在编译时是完全没问题的,但由于Push T一个Nodel类型的数据,但在Pop时却要求转换为Node2类型,这将出现程序运 行时的类型转换异常,但却逃离了编译器的检查。 针对object类型栈的问题,我们引入泛型,他可以优雅地解决这些问题。泛型用用一个通过的数据类型T来代替object,在类实例化时指 定T的类型,运行时(Runtime)自动编译为本地代码,运行效率和代码质量都有很大提高,并且保证数据类型安全。 使用泛型实现这个栈 下面是用泛型来重写上面的栈,用一个通用的数据类型T来作为一个占位符,等待在实例化时用一个实际的类型来代替。让我们来看看泛型 的威力: public class StackT private T[] mitem; public T Pop() {???} public void Push(T item){???} publie Stack(int i) { this.m iteni = new T[i]; } } 电 类的写法不变,只是引入了通用数据类型T就可以适用于任何数据类型,并且类型安全的。这个类的调用方法: 〃实例化只能保存int类型的类 Stackint a = new Stackint(1OO); a.Push(10); a.Push(”8888”); 〃这一行编译不通过,因为类a只接收int类型的数据 int x = a.Pop(); 〃实例化只能保存string类型的类 Stackstring b = new Stackstring(100); b.Push(10); 〃这一行编译不通过,I次l为类b只接收string类型的数据 b.Push(H8888); string y = b.Pop(); 这个类和object实现的类有截然不同的区别: 他是类型安全的。实例化了 int类型的栈,就不能处理string类型的数据,其他数据类型也一样

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档