(erl) erlang进程注册和注销

想要注册一个进程,必须先要创建一个进程。

如何创建一个进程,可以使用产卵,spawn_link,它们虽然都能创建进程,但是也有微妙的区别:

1)当前进程中创建一个并行进程,当被生成的进程崩溃时,当前进程不会察觉

Pid=产卵(有趣)。

2)如果当前进程创建的进程非正常的崩溃,当前进程也会跟着消失

Pid=spawn_link(有趣)。

Erlang中管理注册进程的有4个内置函数,登记,注销,那儿离,注册,它们的用法如下:

1)注册(AnAtom、Pid):将一个进程Pid注册一个名为AnAtom的原子,如果原子AnAtom已经被另一个注册进程所使用,那么注册就会失败。

2)注销(AnAtom):移除与AnAtom相对应进程的所有注册信息。如果一个注册死亡,那么它也会被自动取消注册。

3)那儿离(AnAtom)→Pid |未定义:判断AnAtom是否已经被其他进程注册。如果成功,则返回进程标识符Pid。如果AnAtom没有与之相对应的进程,那么就返回原子定义。

4)注册()→[AnAtom:原子()]:返回一个系统中所有已经注册的名称列表。

此中所说原子不同与java中原子(我记得java中也有原子定义,和线程安全有关),它是一种识别标识。

例子:

模块(聊天)。

出口([/0开始,停止/0])。

开始()→

产卵(有趣的()→

注册(chat_process,自我()),

process_flag (trap_exit,真的),

=open_port港({产卵,“。/聊天”},[{包2}]),

循环(港口)

结束)。

停止()→

chat_process !停止。

循环(港口)→

收到

{电话,来电者,味精}→

港口!{自我(){命令,味精}},

收到{港口,{数据,数据}}→

调用者!{chat_process,数据}

,

循环(港口);

停止→

港口!{自我(),关闭},

收到{港口关闭}→

退出(正常)

,

{}‘退出’,港口,原因→

退出({port_terminated,故})

其中,chat_process,调用,数据,port_terminated等就是一个原子。

当不需要这个注册进程时可以:注销(chat_process)。


(erl) erlang进程注册和注销