skylovesky 2012-04-07
代码如下:
namespace ReflectionOptimization 
{ 
public sealed class TestObject 
{ 
public int Add(int a, int b) 
{ 
// 简单演示 
return a + b; 
} 
} 
} 代码如下:
private static double _Run(string description, Action<int, int> action, int a, int b) 
{ 
if (action == null) throw new ArgumentNullException("action"); 
// 启动计时器 
var stopwatch = Stopwatch.StartNew(); 
// 运行要测量的代码 
action(a, b); 
// 终止计时 
stopwatch.Stop(); 
// 输出结果 
Console.WriteLine("{0}: {1}", description, stopwatch.Elapsed.TotalMilliseconds.ToString(CultureInfo.InvariantCulture)); 
// 返回执行时间 
return stopwatch.Elapsed.TotalMilliseconds; 
} 代码如下:
var obj = new TestObject(); 
var add = obj.GetType().GetMethod("Add"); 
for (var i = 0; i < _TIMES; i++) add.Invoke(obj, new object[] {a, b}); 代码如下:
dynamic obj = new TestObject(); // 有木有发现这个代码超级简单? for (var i = 0; i < _TIMES; i++) obj.Add(a, b);
代码如下:
// 委托 
public delegate int AddMethod(int a, int b); 
// 实现 
var obj = new TestObject(); 
var objType = obj.GetType(); 
var add = objType.GetMethod("Add"); 
var d = (AddMethod)Delegate.CreateDelegate(typeof(AddMethod), obj, add); 
for (var i = 0; i < _TIMES; i++) d(a, b); Debug模式:
| 调用方式 | 第一次 | 第二次 | 第三次 | 第四次 | 第五次 | 
|---|---|---|---|---|---|
| Generic Call | 1.022425 | 1.012885 | 0.990775 | 1.020950 | 1.046880 | 
| Reflection | 147.489220 | 146.012010 | 142.690080 | 139.189335 | 141.663475 | 
| dynamic | 9.645850 | 9.979965 | 9.307235 | 9.532665 | 9.730030 | 
| Func | 1.201860 | 1.214800 | 1.170215 | 1.189280 | 1.239485 | 
| Delegate | 1.062215 | 1.061635 | 1.067510 | 1.047180 | 1.075190 | 
Release模式:
| 调用方式 | 第一次 | 第二次 | 第三次 | 第四次 | 第五次 | 
|---|---|---|---|---|---|
| Generic Call | 0.745600 | 0.741365 | 0.722145 | 0.732630 | 0.725645 | 
| Reflection | 141.778260 | 142.855410 | 142.346095 | 139.649990 | 138.541285 | 
| dynamic | 9.631460 | 10.341850 | 9.284230 | 9.457580 | 9.060470 | 
| Func | 0.882100 | 0.852680 | 0.875695 | 0.854655 | 0.831670 | 
| Delegate | 0.710280 | 0.722465 | 0.723355 | 0.727175 | 0.693320 | 
点评&结论: