向Visual Basic程序员介绍泛型(二)
点击次数:65 次 发布日期:2008-11-06 08:07:51 作者:源代码网
|
源代码网推荐 源代码网推荐正如你所见,泛型使用起来很简单。强类型化的代码可以避免运行时错误;智能感知会工作得更好。虽然使用泛型已经有非常充分的理由,不过使用泛型还有更多的优点:性能和代码重用。 源代码网推荐 源代码网推荐将泛型技术引入.Net框架的一个主要原因是为了提高性能。比如集合类可以比以前工作得更快,因为编译器能够针对集合所储存的类型进行优化。下面的代码比较了数组、ArrayList以及泛型List的性能: 源代码网推荐 源代码网推荐 txtOutput.Text = "Performance" & vbCrLf 源代码网推荐 源代码网推荐 源代码网推荐 源代码网推荐 Const iterations As Integer = 5000000 源代码网推荐 源代码网推荐 PerfTime.Start() 源代码网推荐 源代码网推荐 Dim myArray(iterations) As Integer 源代码网推荐 源代码网推荐 For i As Integer = 0 To iterations - 1 源代码网推荐 源代码网推荐 myArray(i) = i 源代码网推荐 源代码网推荐 Next 源代码网推荐 源代码网推荐 Dim elapsed As Integer = PerfTime.Stop 源代码网推荐 源代码网推荐 txtOutput.Text &= "Array time: " & elapsed & vbCrLf 源代码网推荐 源代码网推荐 myArray = Nothing 源代码网推荐 源代码网推荐 GC.Collect() 源代码网推荐 源代码网推荐 源代码网推荐 源代码网推荐 PerfTime.Start() 源代码网推荐 源代码网推荐 Dim myArrayList As New ArrayList 源代码网推荐 源代码网推荐 For i As Integer = 0 To iterations - 1 源代码网推荐 源代码网推荐 myArrayList.Add(i) 源代码网推荐 源代码网推荐 Next 源代码网推荐 源代码网推荐 elapsed = PerfTime.Stop 源代码网推荐 源代码网推荐 txtOutput.Text &= "ArrayList time: " & elapsed & vbCrLf 源代码网推荐 源代码网推荐 myArrayList = Nothing 源代码网推荐 源代码网推荐 GC.Collect() 源代码网推荐 源代码网推荐 源代码网推荐 源代码网推荐 PerfTime.Start() 源代码网推荐 源代码网推荐 Dim myList As New List(Of Integer) 源代码网推荐 源代码网推荐 For i As Integer = 0 To iterations - 1 源代码网推荐 源代码网推荐 myList.Add(i) 源代码网推荐 源代码网推荐 Next 源代码网推荐 源代码网推荐 elapsed = PerfTime.Stop 源代码网推荐 源代码网推荐 txtOutput.Text &= "List time: " & elapsed & vbCrLf 源代码网推荐 源代码网推荐 myList = Nothing 源代码网推荐 源代码网推荐 GC.Collect() 源代码网推荐 源代码网推荐这段代码在固定长度的数组中储存了500万个数值,同时也在自动增长的ArrayList和泛型List中储存同样多的数值,性能数值看起来非常有趣: 源代码网推荐 源代码网推荐Array 时间: 344 源代码网推荐 源代码网推荐ArrayList时间: 4656 源代码网推荐 源代码网推荐List时间: 797 源代码网推荐 源代码网推荐有特定类型的定长数组有无与伦比的速度,而且不需要为改变大小付出代价。而集合类型的大小都是自动增长,如果有固定数组1/2的性能是相当不错的。接下来看看ArrayList,非常不幸,只有固定数据1/10的性能。问题出在ArrayList被设计成储存引用型变量,Integer是值类型,在储存到ArrayList以前要经过“装箱”操作,将Integer转为Object型。装箱的代价是非常昂贵的,所以当你储存值类型数据(如Integer、Date、Boolean以及你自己创建的Structure等)时,使用泛型将获得非常可观的性能提升。 源代码网推荐 源代码网推荐更多关于“装箱”和“拆箱”操作的信息,请参见MSDN库中的“装箱转换”和“拆箱转换” 源代码网推荐 源代码网推荐创建泛型类型和方法 源代码网推荐 源代码网推荐并不是只能使用Visual Basic.Net提供的泛型类型,你可以创建你自己的泛型类型和方法。 源代码网推荐 源代码网推荐泛型方法 源代码网推荐 源代码网推荐当你想实现一些不与特定类型相关的一般算法时,你可能想创建泛型方法。举个例子,典型的冒泡排序需要遍历数组中的所有项目,两两比较,并交换需要排序的数值。 源代码网推荐 源代码网推荐如果你已经确定只要进行整数的排序,你可以简单地编写一个只能用于Integer类型的Swap方法。但是如果你想能够排序任何类型,你就可以编写一个泛型Swap方法如下: 源代码网推荐 源代码网供稿. |
