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 |
등록 취소 시스템에서 프로세스를 등록 해제하는 데 사용됩니다. |