闁衡偓閹増顥� (0) +1 閻犙嶆嫹 (0) +1 闂婎亷鎷� (0) +1
闁衡偓閹増顥戦柟瀛樺姇婵拷闁哄被鍎冲﹢鍛村绩閹増顥�>>

正在阅读:C#中使用反射的性能分析C#中使用反射的性能分析

2004-10-27 15:31 出处:CSDN 作者:Leafwiz 责任编辑:linjixiong


  for (int i = 0; i < 1000; i++)
  {
  for (int j = 0; j < 100; j++)
  {
  Type theTest = Type.GetType("ReflectionTest.Test.CTester");
  object theobj = theTest.InvokeMember(null, BindingFlags.CreateInstance
  , null, null, null);
  }
  }

  TimeSpan spand = DateTime.Now - now;
  label2.Text = "time past " + spand.ToString();
  }


  测试结果直接调用的时间为16ms左右,而反射调用的则始终维持在5s 520ms左右,直接效率比较接近350倍。
  对于这个测试,很有趣的一点是:
  如果将test2中的Type theTest = Type.GetType("ReflectionTest.Test.CTester");
  移到循环之外,则相应的运行时间下降为1s 332 ms , 效率相差为20倍左右。

  接下来我们对成员函数调用进行了测试:


  test1:

  private void button1_Click(object sender, EventArgs e)
  {
  DateTime now = DateTime.Now;

  CTester aTest = new CTester();
  for (int i = 0; i < 1000; i++)
  {
  for (int j = 0; j < 100; j++)
  {
  
  aTest.test1();
  }
  }

  TimeSpan spand = DateTime.Now - now;
  label1.Text = "time past " + spand.ToString();
  label3.Text = "value is now " + aTest.geta();
  }

  test2:

  private void button2_Click(object sender, EventArgs e)
  {
  DateTime now = DateTime.Now;

键盘也能翻页,试试“← →”键

关注我们

最新资讯离线随时看 聊天吐槽赢奖品
闁归潧顑嗗┃鈧悹浣告健濡拷闁搞儳鍋涢崺灞俱亜閸洖鍔�