在Erlang中收听消息

use*_*280 0 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.
Run Code Online (Sandbox Code Playgroud)

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

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

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

6> spawn(masterNode, listen, []).     
<0.47.0>
Run Code Online (Sandbox Code Playgroud)

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

mn ! {userNode1, createNode}. %Create a userNode process called userNode1
Run Code Online (Sandbox Code Playgroud)

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

Ale*_*pov 6

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

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