标签:
Erlang最开始是为了电信产品而发展起来的语言,因为这样的目的,决定了她对错误处理的严格要求。Erlang除了提供exception,try catch等语法,还支持Link和Monitor两种监控进程的机制,使得所有进程可以连接起来,组成一个整体。当某个进程出错退出时,其他进程都会收到该进程退出的消息通知。有了这些特点,使用erlang建立一个简单,并且健壮的系统就不是什么难事。
进程双向监控-Link
link方式可以建立进程之间的双向链接关系,当其中一个进程退出时,另一个进程会收到该进程退出的消息。
例子1:
运行代码:
注:erlang进程默认不捕捉Exit信号,可以使用process_flag(trap_exit, true)改变这一默认行为。
注2:解除link监控用erlang:unlink(Pid)
进程单向监控-Monitor
Monitor方式则实现进程的单向监控,当被监控进程退出时,监控进程会收到该进程退出的消息。
例子2:
运行代码:
注:解除monitor监控用erlang:demonitor(MonitorRef)
如果进程是以 normal 方式退出,erlang将不会发出进程退出通知
转自: http://blog.csdn.net/mycwq/article/details/13171117
标签:
原文地址:http://www.cnblogs.com/unqiang/p/4581463.html