using System; using System.Reflection; using System.Diagnostics; namespace Refl { class Test { public void Method() { } } class MainClass { const int loops = 100000000; Test m_Test = new Test(); Action m_Action; public MainClass() { Type t = typeof(Test); MethodInfo m = t.GetMethod("Method"); m_Action = (Action)Delegate.CreateDelegate(typeof(Action), m_Test, m); } public void Test1() { Stopwatch stopWatch = new Stopwatch(); stopWatch.Start(); for (int i = 0; i < loops; ++i) { m_Test.Method(); } stopWatch.Stop(); Console.WriteLine("Test1 - direct invoke: " + stopWatch.ElapsedMilliseconds); } public void Test2() { Stopwatch stopWatch = new Stopwatch(); stopWatch.Start(); for (int i = 0; i < loops; ++i) { m_Action(); } stopWatch.Stop(); Console.WriteLine("Test2 - delegate invoke: " + stopWatch.ElapsedMilliseconds); } public static void Main(string[] args) { MainClass main = new MainClass(); main.Test1(); main.Test2(); Console.ReadKey(); } } }
Xamarin - Release結果
第一次:
Test1 - direct invoke: 633 ms
Test2 - delegate invoke: 527 ms
第二次
Test1 - direct invoke: 644 ms
Test2 - delegate invoke: 661 ms
第三次
Test1 - direct invoke: 621 ms
Test2 - delegate invoke: 646 ms