当前位置: 首页 > 文档资料 > Erlang 中文教程 >

进程( Processes)

优质
小牛编辑
135浏览
2023-12-01

Erlang中的并发粒度是一个过程。 进程是与其他进程同时运行并独立于其他进程的活动/任务。 Erlang中的这些进程与大多数人熟悉的进程和线程不同。 Erlang进程是轻量级的,在(内存)与其他进程隔离的情况下运行,并由Erlang的虚拟机(VM)调度。 进程的创建时间非常短,刚生成的进程的内存占用非常小,并且单个Erlang VM可以运行数百万个进程。

在spawn方法的帮助下创建一个进程。 该方法的一般语法如下。

语法 (Syntax)

spawn(Module, Name, Args)

参数 (Parameters)

  • Module - 这是一个预定义的原子值,必须是?MODULE。

  • Name - 这是定义进程时要调用的函数的名称。

  • Args - 这些是需要发送给函数的参数。

返回值 (Return Value)

返回创建的新进程的进程ID。

例如 (For example)

以下程序中显示了spawn方法的示例。

-module(helloworld). 
-export([start/0, call/2]). 
call(Arg1, Arg2) -> 
   io:format("~p ~p~n", [Arg1, Arg2]). 
start() -> 
   Pid = spawn(?MODULE, call, ["hello", "process"]), 
   io:fwrite("~p",[Pid]).

关于上述程序需要注意以下事项。

  • 定义了一个名为call的函数,它将用于创建进程。

  • spawn方法使用参数hello和process调用call函数。

输出 (Output)

当我们运行上述程序时,我们将得到以下结果。

<0.29.0>"hello" "process"

现在让我们看一下流程可用的其他功能。

Sr.No.方法和描述
1

is_pid

此方法用于确定进程ID是否存在。

2

is_process_alive

这称为is_process_alive(Pid)。 Pid必须引用本地节点上的进程。

3

pid_to_list

它将进程ID转换为列表。

4

registered

返回包含所有已注册进程名称的列表。

5

self

最常用的BIF之一,返回调用进程的pid。

6

register

这用于在系统中注册进程。

7

whereis

它被称为whereis(Name)。 返回使用名称注册的进程的pid。

8

unregister

这用于取消注册系统中的进程。