Erlang中的注册进程使用实例_Erlang

之前看到 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().

时间: 2024-10-27 08:10:06

Erlang中的注册进程使用实例_Erlang的相关文章

Erlang分布式节点中的注册进程使用实例_Erlang

上一篇文章中说到, 注册进程关联的原子具有全局作用域, 这里的全局指的是当前 Erlang 虚拟机, 在分布式中, 便是当前分布式节点. 因此, 在一个节点中注册进程关联的原子, 在另一个节点中是不能直接使用, 而必须配和目标节点使用. 复制代码 代码如下: {RegName, Node} ! {messages}. 例子 先启动一个 Server 节点 复制代码 代码如下: erl -sname server 然后在 Erlang Shell 中操作 先简单介绍几个常用函数 复制代码 代码如下

Erlang中的socket编程简单例子_Erlang

Erlang 中gen_tcp 用于编写TCP程序,gen_udp用于编写UDP程序.一个简单的TCP服务器echo示例: 复制代码 代码如下: Start_echo_server()->          {ok,Listen}= gen_tcp:listen(1234,[binary,{packet,4},{reuseaddr,true},{active,true}]),          {ok,socket}=get_tcp:accept(Listen),          gen_tc

Erlang中的模块与模式匹配介绍_Erlang

模块是Erlang的基本代码单元,erl文件编译后以.beam作为扩展名,采用UTF8字符集,.erl文件示意如下: -module(模块名,与存放模块的文件名相同) -export([方法名/输入参数的个数]) 复制代码 代码如下: Method1( {a,b,c})->a*b*c; Mehtod2({d,e})->d-e. 模块属性有两种类型:预定义型和用户定义型.   Erlang中用于代表函数的数据类型被称为fun,相当于python中的lambda,一般用于 1)      对列表里

Erlang中的并发程序简介_Erlang

Erlang中基本的并发函数 1)  Pid =spwan(Mod,Func,Args) 创建一个新的进程来执行apply(Mod,Func,Args),与调用进程并列运行,会使用最新的代码定义模块. 2)  Pid!Message 向Pid进程异步发送Message,!为发送操作符 3)  Receive - end 接收消息 复制代码 代码如下:  receive            Pattern1[when Guard1]-> Expression1;            Patte

Erlang中的函数与流程控制介绍_Erlang

一:函数 1:在Erlang中,[名字相同但参数数目不同]的两个函数是完全不同的函数. 2:其他模块内的函数用完全限定名称 被调用: 复制代码 代码如下: -module(sort1). -export([reverse_sort/1, sort/1]). reverse_sort(L) ->         lists1:reverse(sort(L)). sort(L) ->         lists:sort(L). 3:子句间以分号[;]分隔,在最后的结尾处以[.]结尾. 4:每个函

Erlang中的映射组Map详细介绍_Erlang

主要是遇到 Map匹配的问题,所以顺便回忆一下 Erlang 中的映射组 Map,在其它语言中被称作 Hash 哈希或者 Dict 字典. Erlang 从 R17 版本开始支持映射组 创建映射组 Erlang 中的映射组用结构 #{} 表示,创建一个映射组可以这样 复制代码 代码如下: % 不管你怎么排序,最终结果都是按键的字典顺序排列的 #{ name => "wittyfox", age => 19 }. % => #{age => 20,name =&g

Erlang中的匹配模式总结_Erlang

一.赋值时匹配 原子匹配 复制代码 代码如下: atom    = atom                        % atom another = another                     % another atom    = another                     % exception error 变量匹配 复制代码 代码如下: Var = 2.                              % 2 Var = 3 - 1.       

Erlang中的基本元素操作小结_Erlang

Erlang shell中,用句号加空格.tab或回车来结束表达式,%表示注释的起点,;隔离子句.模块是.erl 文件,库的头文件.hrl, shell中的编译时c(),外编译命令时erlc, 退出shell用q(),或erlang:halt(). 变量以大写字母开头,且不能重新绑定变量,只能一次性赋值,具有不可变状态.原子是全局的,不需要宏定义或包含文件,以小写字母开头,还可放在单引号内,是极简表达式.   元组(tuple)是一些数量固定的项目归组成单一实体{,}, 由于是匿名的,通常在第一

【整理】Erlang 中的 supervisor

[概况] supervisor behaviour 是用来实现监控其他子进程的 supervisor 进程的模块: 子进程可以是另一个 supervisor 进程,也可以是一个 worker 进程: worker 进程一般使用 gen_event,gen_fsm 或 gen_server behaviour 来实现 : 一个使用 supervisor behaviour 实现的 supervisor 有一个接口方法的标准集,包括跟踪和错误报告的功能: supervisor 机制用来构建一个分层进