zoukankan      html  css  js  c++  java
  • 装箱和拆箱所引发的性能问题

    C#中的装箱,拆箱操作过程随处可见,装箱:将一个值类型转换成一个oject类型;拆箱:将一个object类型转换成值类型。装箱也就是创建了一个object实例,并将这个值复制给这个object,装箱后object对象中的数据存放在托管堆中,托管堆的地址放在堆栈中,是作为一个复制文件赋值给对象的。

    装箱和拆箱需要进行大量计算,对值类型装箱需要分配一个全新的对象,次之,取消装箱也需要进行大量的计算,减少装箱和拆箱操作对应用程序的性能有很好的途径。所以在.NET Framework 2.0时候微软推出泛型,他有效的解决了这个性能的问题。

    代码
    1 class Program
    2 {
    3 static void Main(string[] args)
    4 {
    5 RunBox();
    6 RunNoBox();
    7 }
    8 /// <summary>
    9 /// 装箱
    10 /// </summary>
    11   public static void RunBox()
    12 {
    13 DateTime startTime = DateTime.Now;
    14 ArrayList list = new ArrayList();
    15 for (int i = 0; i < 5; i++)
    16 {
    17 list.Clear();
    18 for (int j = 0; j < 5000000; j++)
    19 {
    20 list.Add(j);
    21 }
    22 int k;
    23 for (int j = 0; j < list.Count; j++)
    24 {
    25 k = (int)list[i];
    26 }
    27 }
    28 DateTime endTime = DateTime.Now;
    29 Console.WriteLine("开始时间,结束时间,耗费时间"+ startTime.ToString()+","+endTime.ToString()+",'"+(endTime - startTime).ToString());
    30 }
    31 /// <summary>
    32 /// 拆箱
    33 /// </summary>
    34   public static void RunNoBox()
    35 {
    36 DateTime startTime = DateTime.Now;
    37 List<int> list = new List<int>();
    38 for (int i = 0; i < 5; i++)
    39 {
    40 list.Clear();
    41 for (int j = 0; j < 5000000; j++)
    42 {
    43 list.Add(j);
    44
    45 }
    46 int k;
    47 for (int j = 0; j < list.Count; j++)
    48 {
    49 k = list[j];
    50
    51 }
    52
    53 }
    54 DateTime endTime = DateTime.Now;
    55 Console.WriteLine("开始时间,结束时间,耗费时间" + startTime.ToString() + "," + endTime.ToString() + ",'" + (endTime - startTime).ToString());
    56 }
    57 }
    58 }
    怀揣着一点点梦想的年轻人
    相信技术和创新的力量
    喜欢快速反应的工作节奏
  • 相关阅读:
    程序员励志语录
    javaEE的十一种技术
    gui内函数调用顺序
    m文件中函数的执行顺序
    VC++与Matlab混合编程之引擎操作详解(6)数据类型mxArray的操作
    GUI(2)
    时间管理
    Matlab GUI界面
    matlab GUI(2)
    MATLAB GUI平台
  • 原文地址:https://www.cnblogs.com/hfliyi/p/1944682.html
Copyright © 2011-2022 走看看