时间:2021-05-22
之前看到 Erlang 中的注册进程时,对注册并不理解,主要是不理解注册的原子的作用域。刚才突然想明白了:
复制代码 代码如下:
注册进程关联的原子具有全局作用域
也就是说关联了注册进程之后的原子可以全局被使用
Erlang 中的并发机制是通过消息邮箱实现的,进程间进行通讯的方式只有消息邮箱,而进程间通讯需要知道进程的进程号,而使用 spawn 产生新进程时会返回新进程的进程号供使用。
一个最简单的进程间通信的程序如下
复制代码 代码如下:
-module(test).
start() ->
spawn(?MODULE, loop, []).
loop() ->
io:format("Waiting for new message.~n"),
receive
M -> io:format("New message: ~p~n", [M])
end,
loop().
在 Erlang Shell 中使用 c(test) 编译这个模块,之后就可以简单的使用了.
在下面的代码中,语句前面的注释表示解释,语句后面的注释表示输出值, % => 后面的值表示语句的返回值
复制代码 代码如下:
% 编译这个模块
c(test).
% 开启无限循环
Pid = test:start().
% Waiting for new message. % 新进程 spawn 后立刻运行
% => <0.35.0> % 返回新进程的进程号
% 向进程发送消息
Pid ! 'message'.
% New message: message % 接收到消息
% Waiting for new message. % 继续接收消息
% => message % 语句返回值,而非进程返回消息
为了用户不用每次都 Pid ! 'message',可以加入一个 call 方法进行包装一下。
复制代码 代码如下:
call(Pid, M) ->
Pid ! M.
这样就可以使用 test:call(Pid, 'message') 发送消息了。
但是这样写还有个明显的弊端,调用 call 时需要 Pid 参数,但是又不能去掉,因为需要进程号才能通信,所以使用时需要用户维护一个进程号。
而 Erlang 提供了注册进程的机制用来把原子关联到进程中,可以解决这个问题
使用 register(atom, Pid) 可以将 atom 关联到进程号为 Pid 的进程上,这个原子就
修改上面的 start 函数为
复制代码 代码如下:
start() ->
register(testp, spawn(?MODULE, loop, [])).
这样,新的进程将关联到原子 testp,此时原子就可以当作 Pid 那样使用 "消息发送操作符" !
复制代码 代码如下:
testp ! 'message'
于是可以修改上面的 call 函数,去掉 Pid 参数,而使用关联后的原子,这个关联后的原子不止在模块内有效,在全局作用域中都是有效的。
复制代码 代码如下:
call(M) ->
testp ! M.
因此使用注册进程修改后的程序如下
复制代码 代码如下:
-module(test).
start() ->
register(testp, spawn(?MODULE, loop, [])).
loop() ->
io:format("Waiting for new message.~n"),
receive
M -> io:format("New message: ~p~n", [M])
end,
loop().
call(M) ->
testp ! M.
注册相关的 BIF
复制代码 代码如下:
% 注册 atom 到 Pid
register(atom, Pid).
% 取消 atom 的注册
unregister(atom).
% 返回 atom 关联的进程号,如果未关联,返回 undefined
whereis(atom).
% 返回系统中所有已注册的进程名
registered().
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
上一篇文章中说到,注册进程关联的原子具有全局作用域,这里的全局指的是当前Erlang虚拟机,在分布式中,便是当前分布式节点.因此,在一个节点中注册进程关联的原子
Erlang中基本的并发函数1)Pid=spwan(Mod,Func,Args)创建一个新的进程来执行apply(Mod,Func,Args),与调用进程并列运
Erlang目前已经是Fedora和Debian/Ubuntu软件仓库中的一部分。Erlang目前最新的版本是OTP17.0。Erlang是一种编程语言,用于构
本文实例讲述了php多进程中的阻塞与非阻塞操作。分享给大家供大家参考,具体如下:我们通过pcntl_fork来创建子进程,使用pcntl_wait和pcntl_
本文实例讲述了PHP的pcntl多进程用法。分享给大家供大家参考。具体分析如下:PHP使用PCNTL系列的函数也能做到多进程处理一个事务。比如我需要从数据库中获