[erl]erlang进程注册和注销-创新互联

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

成都创新互联公司是一家专注于成都做网站、成都网站建设与策划设计,温岭网站建设哪家好?成都创新互联公司做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:温岭等地区。温岭做网站价格咨询:13518219792

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

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

Pid = spawn(Fun).

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

Pid = spawn_link(Fun).

Erlang中管理注册进程的有4个内置函数,register、unregister、whereis、registered,它们的用法如下:  

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

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

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).

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站栏目:[erl]erlang进程注册和注销-创新互联
标题来源:http://ybzwz.com/article/jjgdh.html