欢迎来到天天文库
浏览记录
ID:50783831
大小:53.00 KB
页数:13页
时间:2020-03-14
《DOTNET之美——第1章 C#中的泛型.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、此文档收集于网络,如有侵权,请联系网站删除.NET之美——第1章C#中的泛型.Net1.1版本最受诟病的一个缺陷就是没有提供对泛型的支持。通过使用泛型,我们可以极大地提高代码的重用度,同时还可以获得强类型的支持,避免了隐式的装箱、拆箱,在一定程度上提升了应用程序的性能。本文将系统地为大家讨论泛型,我们先从理解泛型开始。1.1理解泛型1.1.1为什么要有泛型?我想不论大家通过什么方式进入了计算机程序设计这个行业,都免不了要面对数据结构和算法这个话题。因为它是计算机科学的一门基础学科,往往越是底层的部分,对于数据结构或者算法的时间效率和空间效率的要求就越高。比如说,
2、当你在一个集合类型(例如ArrayList)的实例上调用Sort()方法对它进行排序时,.Net框架在底层就应用了快速排序算法。.Net框架中快速排序方法名称叫QuickSort(),它位于Array类型中,这可以通过Reflector.exe你可以将它理解为查看.Net框架源码的一个工具。工具查看到。我们现在并不是要讨论这个QuickSort()实现的好不好,效率高还是不高,这偏离了我们的主题。但是我想请大家思考一个问题:如果由你来实现一个排序算法,你会怎么做?好吧,我们把题目限定得再窄一些,我们来实现一个最简单的冒泡排序(BubbleSort)算法,如果你没
3、有使用泛型的经验,我猜测你可能会毫不犹豫地写出下面的代码来,因为这是大学教程的标准实现:publicclassSortHelper{publicvoidBubbleSort(int[]array){intlength=array.Length;for(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]4、ay[j-1]=temp;}}}}}对冒泡排序不熟悉的读者,可以放心地忽略上面代码的方法体,它不会对你理解泛型造成丝毫的障碍,你只要知道它所实现的功能就可以了:将一个数组的元素按照从小到大的顺序重新排列。我们对这个程序进行一个小小的测试:classProgram{staticvoidMain(string[]args){SortHelpersorter=newSortHelper();int[]array={8,1,4,7,3};sorter.BubbleSort(array);foreach(intiinarray){Console.Write("{0}",i5、);}Console.WriteLine();Console.ReadKey();}}输出为:13478我们发现它工作良好,欣喜地认为这便是最好的解决方案了。直到不久之后,我们需要对一个byte类型的数组进行排序,而我们上面的排序算法只能接受一个int类型的数组,尽管我们知道它们是完全兼容的,因为byte类型是int类型的一个子集,但C#是一个强类型的语言,我们无法在一个接受int数组类型的地方传入一个byte数组。好吧,没有关系,现在看来唯一的办法就是将代码复制一遍,然后将方法的签名改一个改了:publicclassSortHelper{此文档仅供学习与交流此6、文档收集于网络,如有侵权,请联系网站删除publicvoidBubbleSort(int[]array){intlength=array.Length;for(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]7、(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]8、站删除样做的目的是为了避
4、ay[j-1]=temp;}}}}}对冒泡排序不熟悉的读者,可以放心地忽略上面代码的方法体,它不会对你理解泛型造成丝毫的障碍,你只要知道它所实现的功能就可以了:将一个数组的元素按照从小到大的顺序重新排列。我们对这个程序进行一个小小的测试:classProgram{staticvoidMain(string[]args){SortHelpersorter=newSortHelper();int[]array={8,1,4,7,3};sorter.BubbleSort(array);foreach(intiinarray){Console.Write("{0}",i
5、);}Console.WriteLine();Console.ReadKey();}}输出为:13478我们发现它工作良好,欣喜地认为这便是最好的解决方案了。直到不久之后,我们需要对一个byte类型的数组进行排序,而我们上面的排序算法只能接受一个int类型的数组,尽管我们知道它们是完全兼容的,因为byte类型是int类型的一个子集,但C#是一个强类型的语言,我们无法在一个接受int数组类型的地方传入一个byte数组。好吧,没有关系,现在看来唯一的办法就是将代码复制一遍,然后将方法的签名改一个改了:publicclassSortHelper{此文档仅供学习与交流此
6、文档收集于网络,如有侵权,请联系网站删除publicvoidBubbleSort(int[]array){intlength=array.Length;for(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]7、(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]8、站删除样做的目的是为了避
7、(inti=0;i<=length-2;i++){for(intj=length-1;j>=1;j--){//对两个元素进行交换if(array[j]8、站删除样做的目的是为了避
8、站删除样做的目的是为了避
此文档下载收益归作者所有