不過,JForthBlocks所依賴的以Javascript開發的JeForth,DoLit是否還保有同樣的優勢?
Jimmy's papa動手修改JeForth部份程式碼,再用JForthBlocks同一份積木程式,測試看看有無DoLit的效能,是否有很大的差異,底下是跑五百萬次迴圈的輸出結果,第一次跑出的結果,有無DoLit指令似乎只有幾百微秒(milliseconds)的差異,隨後兩次的結果,執行時間會爆增,或許是垃圾收集機制的干擾
首先,測試compilecode('doLit',n)的效能
function call(xt){// high level definition inner execution loop
highLevelLooping=true; ip=xt;
do{
var id=dictionary[ip++];
//if(typeof(id)=='object'){var v=id['lit'];stack.push(v);continue;}
........
........
}
}
function exec(src){ //source code interpreting loop
.....
.....
do{token=nexttoken(); word=token;
var id=findword(token);
......
......
if(typeof(n)==='string'||n<=0||n>0){
if(compiling)
compilecode('doLit',n);// compile an literal
//compilecode({lit : n});
......
......
}while(error===0&&ntib<tib.length);}
}
![]() |
寄件者 scratchlab02 |
data:image/s3,"s3://crabby-images/8e06a/8e06a3c758602233166766c4cf628da3be34e195" alt=""
data:image/s3,"s3://crabby-images/4e314/4e3142ad1bf3e3073588f27df33461e297d66f8d" alt=""
data:image/s3,"s3://crabby-images/534c6/534c62862d68f137ecdd08a997323e4cb6758aad" alt=""
再來,測試compilecode({lit : n})的效能,執行時則統一由call(xt)代勞取字面值(literal)
function call(xt){// high level definition inner execution loop
highLevelLooping=true; ip=xt;
do{
var id=dictionary[ip++];
if(typeof(id)=='object'){var v=id['lit'];stack.push(v);continue;}
........
........
}
}
function exec(src){ //source code interpreting loop
.....
.....
do{token=nexttoken(); word=token;
var id=findword(token);
......
......
if(typeof(n)==='string'||n<=0||n>0){
if(compiling)
//compilecode('doLit',n);// compile an literal
compilecode({lit : n});
......
......
}while(error===0&&ntib<tib.length);}
}
![]() |
寄件者 scratchlab02 |
data:image/s3,"s3://crabby-images/c1175/c1175be5cf678dbe80dde9002179c1c558991632" alt=""
data:image/s3,"s3://crabby-images/4b631/4b63160d48cb8c5032e2be0c058ab0e94e937f70" alt=""
data:image/s3,"s3://crabby-images/223bb/223bb445cb916022ad5a340d0605666597c8ebe4" alt=""
底下是積木的XML,可以貼到JForthBlocks的XML編輯區,便會將這次測試所用到的積木載入
<xml xmlns="http://www.w3.org/1999/xhtml">
<block type="procedures_defnoreturn" notchtype="Top_Bottom_Right" inline="false" x="137" y="55">
<title name="NAME">TestLiteral</title>
<statement name="STACK">
<block type="math_PushNumber" notchtype="TOP_BOTTOM">
<title name="NUM">5000000</title>
<next>
<block type="control_ForNext" notchtype="Top_Bottom_Right" inline="false">
<statement name="STACK">
<block type="math_PushNumber" notchtype="TOP_BOTTOM_RIGHT" inline="false">
<title name="NUM">0</title>
<value name="NEXTWORD">
<block type="math_PushNumber" notchtype="LEFT_RIGHT" inline="false">
<title name="NUM">0</title>
<value name="NEXTWORD">
<block type="stack_2drop" notchtype="LEFT_RIGHT" inline="false"></block>
</value>
</block>
</value>
<next>
<block type="math_PushNumber" notchtype="TOP_BOTTOM_RIGHT" inline="false">
<title name="NUM">0</title>
<value name="NEXTWORD">
<block type="math_PushNumber" notchtype="LEFT_RIGHT" inline="false">
<title name="NUM">0</title>
<value name="NEXTWORD">
<block type="stack_2drop" notchtype="LEFT_RIGHT" inline="false"></block>
</value>
</block>
</value>
</block>
</next>
</block>
</statement>
</block>
</next>
</block>
</statement>
</block>
<block type="utility_milliseconds" notchtype="LEFT_RIGHT" inline="false" x="89" y="289">
<value name="NEXTWORD">
<block type="procedures_callnoreturn" notchtype="LEFT_RIGHT" inline="false">
<mutation name="TestLiteral"></mutation>
<value name="NEXTWORD">
<block type="utility_milliseconds" notchtype="LEFT_RIGHT" inline="false">
<value name="NEXTWORD">
<block type="stack_swap" notchtype="LEFT_RIGHT" inline="false">
<value name="NEXTWORD">
<block type="math_Minus" notchtype="LEFT_RIGHT" inline="false">
<value name="NEXTWORD">
<block type="print_DotS" notchtype="LEFT_RIGHT" inline="false"></block>
</value>
</block>
</value>
</block>
</value>
</block>
</value>
</block>
</value>
</block>
</xml>
沒有留言:
張貼留言