-module(test81).
-export([start/1]).
start({N,M,Mess})->
statistics(runtime),
statistics(wall_clock),
L=for(1,N,fun()->spawn(fun()->recv() end) end),
for(1,M,fun()->lists:foreach(fun(Pid)->Pid!Mess end,L) end),
{_,Time1}=statistics(runtime),
{_,Time2}=statistics(wall_clock),
U1=Time1*1000,
U2=Time2*1000,
io:format("~w process ~w times message cost time is:~p(~p)microseconds~n",[N,M,U1,U2]).
recv()->
receive
%Mess->io:format("Pid ~p recv message ~p.~n",[self(),Mess]),
Mess->void,
recv()
end.
for(N,N,F)->[F()];
for(I,N,F)->[F()|for(I+1,N,F)].
我的第一个erlang程序
最新推荐文章于 2025-11-25 10:22:04 发布
本文探讨了并发编程的实现及性能测试方法,通过Erlang的`for`和`spawn`函数实例,展示了如何实现高效的并发操作,并通过性能测试评估不同并发情况下的执行效率。
272

被折叠的 条评论
为什么被折叠?



