leex文法分析的效率

R13B新添加的leex相当于c的lex, 在做文法分析非常方便,但是效率如何呢? leex的example里面带了个erlang_scan和erlang标准的发布版的erl_scan兼容,所以我们来对比测试下效率。 

注意用R13B03,因为R13B02的erlc漏掉了编译xrl格式。 

以下是实验: 

root@nd-desktop:~# git clone git://github.com/rvirding/leex.git 
root@nd-desktop:~# cd leex/examples/ 
root@nd-desktop:~/leex/examples# cat test_scan.erl 
-module(test_scan). 
-export([start/1]). 
start([A])-> 
    {ok, F} = file:open(atom_to_list(?MODULE)++".erl", [read]), 
    {ok, S} = file:read(F, 9999999), 
    file:close(F), 
    N = list_to_integer(A), 
    test(N, fun erlang_scan:string/1, S, "erlang_scan"), 
    test(N, fun erl_scan:string/1, S, "erl_scan"), 
    ok. 

test(N, F, S, Ts)-> 
    Start = erlang:now(),    
    dotimes(N, fun (_) -> 
                       F(S) 
               end), 
    io:format("~s run ~w ms~n", [Ts,round(timer:now_diff(now(), Start) /1000)]). 

dotimes(0, _) -> done; 
dotimes(N, F) -> 
    F(N), 
    dotimes(N - 1, F). 

root@nd-desktop:~/leex/examples# erlc erlang_scan.xrl 
root@nd-desktop:~/leex/examples# ls *.erl 
erlang_scan.erl  test_scan.erl 
root@nd-desktop:~/leex/examples# erlc *.erl 
root@nd-desktop:~/leex/examples# erl -noshell -run test_scan start 10000 -s erlang halt 
erlang_scan run 2208 ms 
erl_scan run 1181 ms 

%% 这个版本稍微慢点 

root@nd-desktop:~/leex/examples# erlc +native *.erl 
root@nd-desktop:~/leex/examples# erl -noshell -run test_scan start 10000 -s erlang halt 
erlang_scan run 1292 ms 
erl_scan run 1238 ms 

结论是: leex产生的代码和手写的效率几乎差不多。 
posted @ 2010-10-27 18:17  麦飞  阅读(264)  评论(0编辑  收藏  举报