- A+
所属分类:.NET C#
在使用ArrayList这样的非泛型集合的过程中,要进行装箱和拆箱操作,会有比较大的性能损失,而使用泛型集合就没有这样的问题。List是泛型,而ArrayList是非泛型。存数据岛ArrayList都需要专程object,读取又要转换成相应的数据类型,List则不需要。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
//用来记录开始和结束的时间 DateTime startTime = new DateTime(); DateTime endTime = new DateTime(); //定义集合类型ArrayList的一个实例 ArrayList list = new ArrayList(); //取得当前时间 startTime = DateTime.Now; //★★★★★★★★①使用ArrayList类★★★★★★★★ //ArrayList的add方法的参数是Object型, //当我们把int型作为参数传入的时候需要做装箱操作 //装箱操作将值类型转化为Object类型 for (int i = 0; i < 1000000; i++) { list.Add(i); } int iCount = 0; //当我们使用int型的时候需要做拆箱操作操作 //拆箱操作将应用类型转化为Object类型,拆箱过程要做大量的工作 foreach (int i in list) { iCount += 1; } Console.WriteLine("使用ArrayList的结果 : {0}", iCount.ToString()); //取得结束时间并计算差值 endTime = DateTime.Now; TimeSpan ts = endTime - startTime; Console.WriteLine("使用ArrayList的耗时 :" + ts.TotalMilliseconds); //★★★★★★★★②使用泛型类★★★★★★★★ //使用List的泛型定义List<T>,int类型在编译器动态生成的类中本替换为int型 //执行过程中不再执行装箱拆箱操作 List<int> list2 = new List<int>(); startTime = DateTime.Now; for (int i = 0; i < 1000000; i++) { list2.Add(i); } iCount = 0; foreach (int i in list2) { iCount += 1; } Console.WriteLine("使用泛型的结果 : {0}", iCount.ToString()); endTime = DateTime.Now; ts = endTime - startTime; Console.WriteLine("使用泛型的耗时 :" + ts.TotalMilliseconds); //显示三次结果如下 /* 第一次 * 使用ArrayList的耗时 :92 * 使用泛型的耗时 :25 * * 第二次 * 使用ArrayList的耗时 :96 * 使用泛型的耗时 :22 * * 第三次 * 使用ArrayList的耗时 :90 * 使用泛型的耗时 :22 * * 由此可以明显看出两者的差别 * 这里仅仅是时间上的,并不包括对内存消耗的统计 * * ※但是也要注意到差别的单位是毫秒, * 我这里只想说明用泛型是有好处的, * 但也不可过分追求程序的孰优孰劣, * 总之要把握好这个度,适合自己的才是最好的 * O(∩_∩)O~ */ Console.Read(); |
转自:http://blog.csdn.net/gishero/article/details/5255792

微信公众号
扫一扫关注运维生存时间公众号,获取最新技术文章~
30/04/2014 下午 9:32 沙发
白开胸会JAVA?
01/05/2014 下午 3:35 1层
@路一起 略懂
01/05/2014 下午 11:00 1层
@路一起 你还知道ArrayList
02/05/2014 上午 12:42 2层
@杰克船长 我学JAVA出身的