Erlang (programming language)/Tutorials/Processes: Difference between revisions

From Citizendium
Jump to navigation Jump to search
imported>Eric Evers
mNo edit summary
imported>Eric Evers
Line 3: Line 3:
==Erlang Processes and Messages==
==Erlang Processes and Messages==


Processes are easy to create and control in erlang. The program chain_hello.erl builds a chain of processes as long as you like. Each process creates one process then sends a message to it. The program creates a chain of N processes which each print out hello world! N. Processes send messages and receive messages from one another. Messages are read with pattern matching. The messages are matched in a fifo(first in, first out) way.
Processes are easy to create and control in erlang. The program chain_hello.erl builds a chain of processes as long as you like. Each process creates one process then sends a message to it. The program creates a chain of N processes which each print out hello world! N. Processes send messages and receive messages from one another. Messages are read with pattern matching. The messages are matched in a fifo(first in, first out) way.


Note 1: the order of the final output depends on process scheduling.
Note 1: The order of the final output depends on process scheduling.


Note 2: time flows downward(in each vertical line, see note 1).
Note 2: Time flows downward(in each vertical line for each process, see note 1).






This is a Process Message Diagram for the execution of: chain_hello:start(1).  
This is a minimal UML sequence diagram showing the processes and messages for the execution of:
                 
chain_hello:start(1).  
  start(1)
UML sequence notation: Processes start in boxes. Processes end in X's. 
     |
Note: Some of the details of have been left out for tutorial purposes.
  spawns ———————————> listen(1)
      The diagram is mostly in English rather than code.
     |                  |
Local notation: Command line output is in quotes. Messages are in curly braces.
     |                spawns —————————————————————> listen(0)
 
     |                  |                            |
+——————————+                 
     |                sends ————> speak ——————————> prints --> "hello world 0"
  | start(1) |
     |                  |                            |
+——————————+
  sends ——> speak > prints ——> "hello world 1"    |
     ¦              +———————————+
                        |                            |
  spawns ———————> | listen(1) |
                        ok                          ok
    ¦              +———————————+
     ¦                    ¦                      +———————————+
     ¦                  spawns ————————————————> | listen(0) |
     ¦                    ¦                      +———————————+
     ¦                    ¦                          ¦
sends > {speak} —> prints > "hello world 1"   ¦
     ¦                    ¦                          ¦
    ¦                  sends ——> {speak} ———————> prints ———> "hello world 0"
     ¦                    ¦                          ¦
    X                    X                          X


Program listing for: chain_hello.erl
Program listing for: chain_hello.erl
Line 47: Line 56:
         end.
         end.


  % ---- sample output ---- %
  % ---- sample output for chain_hello:start(1) --- %
%
% 14> chain_hello:start(1).
% done
% okhello world!1
% hello world!0
%
% ---- sample output for chain_hello:start(4) --- %
  %
  %
  % 14> chain_hello:start(4).
  % 14> chain_hello:start(4).

Revision as of 10:26, 17 November 2008


Erlang Processes and Messages

Processes are easy to create and control in erlang. The program chain_hello.erl builds a chain of processes as long as you like. Each process creates one process then sends a message to it. The program creates a chain of N processes which each print out hello world! N. Processes send messages and receive messages from one another. Messages are read with pattern matching. The messages are matched in a fifo(first in, first out) way.

Note 1: The order of the final output depends on process scheduling.

Note 2: Time flows downward(in each vertical line for each process, see note 1).


This is a minimal UML sequence diagram showing the processes and messages for the execution of:

chain_hello:start(1). 
UML sequence notation: Processes start in boxes. Processes end in X's.  
Note: Some of the details of have been left out for tutorial purposes. 
      The diagram is mostly in English rather than code.
Local notation: Command line output is in quotes. Messages are in curly braces. 
+——————————+                  
| start(1) | 
+——————————+
   ¦              +———————————+
spawns  ———————>  | listen(1) |
   ¦              +———————————+
   ¦                    ¦                      +———————————+
   ¦                  spawns ————————————————> | listen(0) |
   ¦                    ¦                      +———————————+
   ¦                    ¦                          ¦
sends  —> {speak} —> prints  —> "hello world 1"    ¦
   ¦                    ¦                          ¦
   ¦                  sends ——> {speak} ———————> prints  ———> "hello world 0"
   ¦                    ¦                          ¦
   X                    X                          X

Program listing for: chain_hello.erl

-module(chain_hello). 
-compile(export_all).
                                                            %
start(N)->                                                  % startup
       Pid1 = spawn(chain_hello, listen, [N]),
       Pid1 ! speak,
       io:format("done \n").
                                                            %
listen(0)->                                                 % base case
       receive
                speak ->
                       io:format("hello world!~w\n", [0])
       end;
listen(N)->                                                 % recursive case
       Pid2= spawn(chain_hello, listen, [N-1]),
       Pid2! speak,
       receive
               speak->
                       io:format("hello world!~w\n", [N])
       end.
% ---- sample output for chain_hello:start(1) --- %
%
% 14> chain_hello:start(1).
% done
% okhello world!1
% hello world!0
%
% ---- sample output for chain_hello:start(4) --- %
%
% 14> chain_hello:start(4).
% done
% hello world!4
% hello world!3
% hello world!2
% okhello world!1
% hello world!0