正文
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
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();
因此效率很低