erlang笔记2

来源:互联网 发布:电脑管理软件 知乎 编辑:程序博客网 时间:2024/06/05 17:09

1.两进程的消息传递

以下面程序为例:

-module(tut16).-export([start/0, ping/1, pong/0]).
ping(0) ->    pong ! finished,  %% finished 给了”pong(像下面所
    io:format("ping finished~n", []);
ping(N) ->    pong ! {ping, self()},  %%表示 self()回当前自行的进程 ID,在这里ping的进程 ID。    receive
        pong ->            io:format("Ping received pong~n", [])
    end,    ping(N - 1).
pong() ->    receive
        finished ->            io:format("Pong finished~n", []);
        {ping, Ping_PID} ->            io:format("Pong received ping~n", []),            Ping_PID ! pong,            pong()

end.

start() ->    register(pong, spawn(tut16, pong, [])), %% 进程名称注册     spawn(tut16, ping, [3]).
2> c(tut16).{ok, tut16}3> tut16:start().<0.38.0>Pong received pingPing received pongPong received pingPing received pongPong received pingPing received pongping finishedPong finished


总结:

1.Erlang内建函数spawn用于建一个新的进程:spawn(模块, 导出的函数, 参数列表) 

2.发送消息方法:Pid ! Message , ,Message(东西)发到给了为 Pid 的进程。

3.receive用于允许进程来自其它进程的息。它的式是: 

receive   pattern1 ->
       actions1;   pattern2 ->
       actions2;   ....
   patternN       actionsN

end. 

,在结尾没”;”。 










原创粉丝点击