[erl] erlang 進程註冊和註銷

想要註冊一個進程,必須先要建立一個進程。java

  如何建立一個進程,能夠使用spawn、spawn_link,它們雖然都能建立進程,可是也有微妙的區別:    安全

    1)當前進程中建立一個並行進程,當被生成的進程崩潰時,當前進程不會察覺ide

    Pid = spawn(Fun).函數

    2)若是當前進程建立的進程非正常的崩潰,當前進程也會跟着消失oop

    Pid = spawn_link(Fun).atom

  Erlang中管理註冊進程的有4個內置函數,register、unregister、whereis、registered,它們的用法以下:  spa

    1)register(AnAtom, Pid):將一個進程Pid註冊一個名爲AnAtom的原子,若是原子AnAtom已經被另外一個註冊進程所使用,那麼註冊就會失敗。線程

    2)unregister(AnAtom):移除與AnAtom相對應進程的全部註冊信息。若是一個註冊死亡,那麼它也會被自動取消註冊。orm

    3)whereis(AnAtom) -> Pid | undefined:判斷AnAtom是否已經被其餘進程註冊。若是成功,則返回進程標識符Pid。若是AnAtom沒有與之相對應的進程,那麼就返回原子undefined。進程

    4)registered() -> [AnAtom ::atom()]:返回一個系統中全部已經註冊的名稱列表。

    此中所說原子不一樣與java中原子(我記得java中也有原子定義,和線程安全有關),它是一種識別標識。

例子:

-module(chat).

-export([start/0,stop/0]).

start() ->

  spawn(fun() ->

    register(chat_process,self()),

    process_flag(trap_exit,true),

    Port = open_port({spawn,"./chat"},[{packet,2}]),

    loop(Port)

  end).

stop() ->

  chat_process ! stop.

loop(Port) ->

  receive

    {call,Caller,Msg} ->

      Port ! {self(),{command,Msg}},

      receive

        {Port,{data,Data}} ->

          Caller ! {chat_process,Data}

      end,

      loop(Port);

    stop ->

      Port ! {self(),close},

      receive

        {Port,closed} ->

          exit(normal)

      end;

    {'EXIT',Port,Reason} ->

      exit({port_terminated,Reason})

  end.

其中,chat_process、call、data、port_terminated等就是一個原子.

當不須要這個註冊進程時能夠:unregister(chat_process).

相關文章
相關標籤/搜索