在Erlang中收听消息

时间:2015-02-07 20:55:14

标签: erlang distributed-computing

我正在尝试编写一个函数,它将使进程在接收循环中等待并在输入上进行模式匹配以创建更多进程。

-module(masterNode).

%% ====================================================================
%% API functions
%% ====================================================================
-export([listen/0]).



%% ====================================================================
%% Internal functions
%% ====================================================================


listen() ->
    receive
        {userNodeName, createNode} ->
            spawn(userNode, listen, [userNodeName]),
            io:format("User Node Created!~n"),
            listen();
        {_, createNode} ->
            spawn(userNode, listen, ["Anonymous"]),
            io:format("Anonymous User Node Created!~n"),
            listen();       
        _ ->
            io:format("Invalid syntax!.~n")
    end.

当我尝试从命令行将masterNode生成为变量时,我收到此错误:

5> mn = spawn(masterNode, listen, []).
** exception error: no match of right hand side value <0.44.0>

但是,如果我不尝试将其存储到变量中,我没有问题:

6> spawn(masterNode, listen, []).     
<0.47.0>

我要做的是使用此masterNode变量运行listen命令以激活模式匹配并通过另一个模块(userNode)创建更多进程。像这样:

mn ! {userNode1, createNode}. %Create a userNode process called userNode1

我是Erlang的新手所以我可能会以错误的方式解决这个问题。有什么帮助吗?

1 个答案:

答案 0 :(得分:6)

我也是Erlang的新手,但也许它可能就像这样简单:

mn不是变量,它是一个原子。因此,当您执行atom = statement时,您正在进行比较,而不是作业。尝试将其重命名为Mn或Pid(在大多数教程中使用)。