Erlang-프로세스

Erlang의 동시성 세분성은 프로세스입니다. 프로세스는 다른 프로세스와 동시에 실행되고 독립적 인 활동 / 작업입니다. Erlang의 이러한 프로세스는 대부분의 사람들이 익숙한 프로세스 및 스레드와 다릅니다. Erlang 프로세스는 가볍고 다른 프로세스와 (메모리) 격리 된 상태에서 작동하며 Erlang의 가상 머신 (VM)에 의해 예약됩니다. 프로세스 생성 시간이 매우 짧고 방금 생성 된 프로세스의 메모리 사용량이 매우 적으며 단일 Erlang VM에서 수백만 개의 프로세스를 실행할 수 있습니다.

spawn 메소드의 도움으로 프로세스가 생성됩니다. 메소드의 일반적인 구문은 다음과 같습니다.

통사론

spawn(Module, Name, Args)

매개 변수

  • Module − 이것은? MODULE이어야하는 미리 정의 된 원자 값입니다.

  • Name − 프로세스가 정의 될 때 호출되는 함수의 이름입니다.

  • Args − 함수로 보내야하는 인수입니다.

반환 값

생성 된 새 프로세스의 프로세스 ID를 반환합니다.

예를 들면

다음 프로그램은 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 함수를 호출합니다.

산출

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

<0.29.0>"hello" "process"

이제 프로세스에서 사용할 수있는 다른 기능을 살펴 보겠습니다.

Sr. 아니. 방법 및 설명
1

is_pid

이 방법은 프로세스 ID가 있는지 확인하는 데 사용됩니다.

2

is_process_alive

이를 is_process_alive (Pid)라고합니다. Pid는 로컬 노드의 프로세스를 참조해야합니다.

pid_to_list

프로세스 ID를 목록으로 변환합니다.

4

등기

등록 된 모든 프로세스의 이름이있는 목록을 반환합니다.

5

본인

가장 일반적으로 사용되는 BIF 중 하나는 호출 프로세스의 pid를 반환합니다.

6

레지스터

시스템에 프로세스를 등록하는 데 사용됩니다.

7

어디에

whereis (Name)이라고합니다. 이름으로 등록 된 프로세스의 pid를 반환합니다.

8

등록 취소

시스템에서 프로세스를 등록 해제하는 데 사용됩니다.