[erl] erlang 进程注册和注销
想要注册一个进程,必须先要创建一个进程。
如何创建一个进程,可以使用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).
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?