I'm enjoying the lectures a lot (the two so far). He's a great speaker (is's quite fun to attend classes) and he managed to explain the basic concepts of concurrent erlang programming in 2 hours (provided you already knew the basic erlang syntax).
I'm taking some notes at class, and I'll eventually clean them and upload them in a blogpost format.
For the moment, here is a silly code I wrote the other day while I was in the bus.
It's interesting how:
- Concepts learnt previously in scheme and perl (Higher Order Perl ftw!) become useful and appliable here.
- Pattern matching is stressed to become the basis of method dispatch (with or without guards), variable binding, if/case/any_conditional and message receiving.
- The Message Passing system is GREAT. Not just the "forget about low level sockets" but the mailbox
system of each process, and the transparency that frees you from thinking low level. - Being a functional language, it does tail call optimization, and in most cases you better take advantage of it, because processes (if you think of them as DFA's) have a long life, and they just travel from one state to other by calling themselves recursively with an updated argument (you can
pass the state along through the function arguments).
Here's the code. Just a Proof of concept. Two processes sending pings and pongs one to the other. Pretty simple, but there's pretty much a synopsis of the erlang (ugly) syntax and expressions.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
-module (test1). | |
-export ([f1/2, fact/1 , start/0 , pinger/1, loop/0]). | |
f1 (A) -> | |
A +1. | |
f1 (A, N) -> | |
f1(A). | |
fact (0)-> | |
1; | |
fact (N) -> | |
fact (N-1) * N . | |
start ()-> | |
Pid1 = spawn (test1, loop ,[]), | |
io:format("en start: ~p~n" ,[Pid1]), | |
Pid1 ! foo, | |
Pid2 = spawn (test1, pinger, [Pid1]). | |
pinger (Pid1) -> | |
io:format ("en pinger: ~p~n",[Pid1]), | |
Pid1 ! { self(), ping , "kaka"}, | |
Pid1 ! foo, | |
receive | |
{ok} -> io:format ("back!\n"), | |
Pid1 ! {self (), stop} | |
after | |
2000 -> io:format ("pinger died") | |
end. | |
loop() -> | |
io:format ("hola Matat\n"), | |
receive | |
foo -> | |
io:format ("algo~n"), | |
loop (); | |
{Handle, ping, Msg} -> | |
io:format ("message:[~p] from ~p~n",[ Msg, Handle]), | |
Handle ! {ok}, | |
loop (); | |
{Handle, stop } -> | |
io:format ("stopping~n"); | |
_ -> | |
io:format ("other~n"), | |
loop() | |
after | |
1000 -> io:format ("dying timeout\n") | |
end. |
2 comentarios:
El Johan és l'ídol mundial. De les millors classes que he fet a la FIB ( i el profe havia de ser de fora...). Els labs son xunguillos alguns per això, que si chordy, rudy, etc. jeje.
No estic a la seva classe 'oficial', sinó a un curs ràpid de erlang que està fent a profes (i enchufats :p )
Vaig mirar la seva pagina i vaig veure tots els foobar-y, pero no me'ls he mirat a fons.
Publicar un comentario