erlang链接进程之间的关系
1.process_flag(trap_exit,false),是默认行为:
“A进程”和“B进程”相互链接,(1)如果“A进程”异常退出“B进程”也随之退出;(2)如果“A进程”正常退出,“B进程”不做任何处理,继续运行。
2.process_flag(trap_exit,true):
“A进程”和“B进程”相互链接,“B进程”设置了process_flag(trap_exit,true),这样“B进程”接受到“A进程”的退出信号,并自行处理。
捕获进程退出的编程模式:
模式一:我不在乎创建的进程是否崩溃
创建一个并行进程,当被生成的进程崩溃时,当前进程不会察觉
Pid = spawn(Fun).
模式二:如果我创建的进程非正常的崩溃,我也消亡
Pid = spawn_link(Fun).
模式三:如果我创建的进程崩溃,我需要处理错误
process_flag(trap_exit, true),
Pid = spawn_link(Fun),
process_flag(trap_exit,true)与try link(Pid) catch
process_flag(trap_exit,true)时不能try link(Pid) catch
process_flag(trap_exit,true)把一个进程变成系统进程,捕捉推出信号,并将这些信号和其他消息一样保存在进程信箱中。
在process_flag(trap_exit,true)时,不能对link(Pid)进行try...catch,无论Pid是否存在都catch不到错误。
当Pid不存在时,进程信箱将收到{'EXIT',Pid,noproc}的消息,同时进程继续执行,而不是报错中断。
在process_flag(trap_exit,false)时,link(Pid),当Pid不存在时可以catch到error:_。