C#调用脚本语言(三)-- IronJS 与 IronLua 简单方法性能比较

1.   测试环境

1.1. 硬件环境

CPU:intel Core i7-740QM

内存:8GDDR3 Memory

1.2. 系统

系统:Windows 8 Enterprise

开发工具:Vs2012

1.3. 打开应用

IE(2个博客园页面),VS(2个),Word

1.4. 运行前硬件使用率

CPU:20%

内存:3.8G

 

2.   测试结果

以下测试结果取平均值,单位毫秒

测试脚本

IronJs

IronLua

测试情况

运行循环次数

平均每次运行时间

平均每次输出时间

平均每次运行时间

平均每次输出时间

脚本(3.1)

运行1次

3936.5601

3754.5366

181.0706

39.0323

运行10次

3506.2967

3486.4970

53.4373

38.0273

运行100次

3322.4955

3319.3787

42.0150

39.4533

脚本(3.2)

运行1次

6402.9010

6182.8698

5030.6448

4863.6206

运行10次

5426.4275

5403.8228

2720.1465

2702.3338

运行100次

5264.9106

5261.5463

2305.2731

2302.2437

脚本(3.3)

运行1次

4829.6195

4395.5726

203.9511

64.0034

运行10次

4260.7406

4216.1312

73.1036

57.5132

运行100次

4219.6828

4214.0657

57.9017

54.8742

脚本(3.4)

运行1次

6496.8492

6259.8139

6031.8009

5670.7524

运行10次

5584.7426

5559.5219

3010.6005

2973.0923

运行100次

5364.0077

5359.9148

1889.2121

1884.3506

脚本(3.5)

运行1次

152999.6867

152859.6952

813.1022

445.0527

运行10次

N/A

N/A

475.7581

437.5456

运行100次

N/A

N/A

437.1177

431.8419

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

 


 

3.   测试代码

3.1. C#调用脚本方法,输出,无参

3.1.1.   IronJS

  var v = new IronJS.Hosting.CSharp.Context();

  v.CreatePrintFunction();

 

  v.Execute("function GetFunction(){ var v = 1;}");

  for (int i = 0; i < 10000; i++)

  {

      v.GetFunctionAs<Printdel>("GetFunction")();

  }

 

delegate dynamic Printdel()

3.1.2.   IronLua

  Lua luaVM = new Lua();

  luaVM.DoString("function GetFunction() a=10 end");

 

  for (int i = 0; i < 10000; i++)

  {

       luaVM.GetFunction("GetFunction").Call();

  }

 

3.2. C#调用脚本方法,输出,无参

3.2.1.   IronJS

  var v = new IronJS.Hosting.CSharp.Context();

  v.CreatePrintFunction();

 

  v.Execute("function GetFunction(){ print(1);}");

  for (int i = 0; i < 10000; i++)

  {

      v.GetFunctionAs<Printdel>("GetFunction")();

  }

 

delegate dynamic Printdel()

3.2.2.   IronLua

  Lua luaVM = new Lua();

  luaVM.DoString("function GetFunction() print(1) end");

 

  for (int i = 0; i < 10000; i++)

  {

       luaVM.GetFunction("GetFunction").Call();

  }

 

3.3. C#调用脚本方法,输出,值类型参数

3.3.1.   IronJS

  var v = new IronJS.Hosting.CSharp.Context();

  v.CreatePrintFunction();

 

  v.Execute("function GetFunction(i){ var v = i;}");

  for (int i = 0; i < 10000; i++)

  {

      v.GetFunctionAs<Printdel>("GetFunction")(i);

  }

 

delegate dynamic Printdel(dynamic i)

3.3.2.   IronLua

  Lua luaVM = new Lua();

  luaVM.DoString("function GetFunction(i) a=i end");

 

  for (int i = 0; i < 10000; i++)

  {

       luaVM.GetFunction("GetFunction").Call(i);

  }

3.4. C#调用脚本方法,输出,值类型参数

3.4.1.   IronJS

  var v = new IronJS.Hosting.CSharp.Context();

  v.CreatePrintFunction();

 

  v.Execute("function GetFunction(i){ print(i); }");

  for (int i = 0; i < 10000; i++)

  {

      v.GetFunctionAs<Printdel>("GetFunction")(i);

  }

 

delegate dynamic Printdel(dynamic i)

3.4.2.   IronLua

  Lua luaVM = new Lua();

  luaVM.DoString("function GetFunction(i) print(i) end");

 

  for (int i = 0; i < 10000; i++)

  {

       luaVM.GetFunction("GetFunction").Call(i);

  }

3.5. 脚本调用C#方法,输出,值类型参数

3.5.1.   IronJS

var v = new IronJS.Hosting.CSharp.Context();

Action<string> action1 = new Action<string>((str) => { Console.WriteLine(str);});

 

FunctionObject fun = IronJS.Native.Utils.createHostFunction(v.Environment, action1);

 

v.SetGlobal("print", fun);

 

for (int i = 0; i < 10000; i++)

{

v.Execute(string.Format("print({0});",i));

}

3.5.2.   IronLua

Lua luaVM = new Lua();

luaVM.RegisterFunction("Sleep2", this, this.GetType().GetMethod("LuaSleep"));

 

for (int i = 0; i < 10000; i++)

{

luaVM.DoString("Sleep2(0)");

}

 

(由于时间关系,并未做太多测试,仅仅列出简单形式)

 

PS:

由于本次测试是为接下来的代码脚本化做基础,

所以IronJs调用方法:

定义:v.Execute("function GetFunction(){ print(1);}");

获取、执行:v.GetFunctionAs<Printdel>("GetFunction")();

并非如下形式:

定义:dynamic dy = v.Execute("function GetFunction(){ print(1);}");

执行:dy();

因此效率很低

你可能感兴趣的:(lua)