泛型集合List和非泛型集合ArrayList性能比较

使用ArrayList 这样的非泛型集合过程中,要进行装箱拆箱的操作,会有较大性能的损失

而 List 泛型集合就没有这样的问题

 

ArrayList的add方法的参数是Object类型

当我们把参数传入时会进行装箱操作,将参数转换成Object类型

 

示例:

 

 
  1. DateTime startTime = new DateTime();

  2. DateTime endTime = new DateTime();

  3. //------------------ArrayList ------------------

  4. ArrayList list = new ArrayList();

  5. startTime = DateTime.Now;

  6. //装箱操作

  7. for (int i = 0; i < 1000000; i++)

  8. {

  9. list.Add(i);

  10. }

  11. int iCount = 0;

  12. //拆箱操作

  13. foreach (int i in list)

  14. {

  15. iCount += 1;

  16. }

  17. Console.WriteLine("输出结果 :{0}", iCount.ToString());

  18. endTime = DateTime.Now;

  19. TimeSpan ts = endTime - startTime;

  20. Console.WriteLine("使用ArrayList的结果:{1}" , ts.TotalMilliseconds);

  21.  
  22. //---------------------List---------------

  23. List list2 = new List();

  24. startTime = DateTime.Now;

  25. for (int i = 0; i < 1000000; i++)

  26. {

  27. list2.Add(i);

  28. }

  29. iCount = 0;

  30. foreach (int i in list2)

  31. {

  32. iCount += 1;

  33. }

  34. Console.WriteLine("输出结果 :{0}", iCount.ToString());

  35. endTime = DateTime.Now;

  36. ts = endTime - startTime;

  37. Console.WriteLine("使用ArrayList的结果:{1}" , ts.TotalMilliseconds);

  38. Console.Read();

 

结果:

    使用 ArrayList 耗时:92s

    使用 List耗时:25s 

你可能感兴趣的:(史凯凯的编程技术博客,史凯凯博客馆)