最近写了一个 multi thread 程式
有使用到 ThreadPoolExecutor 之类的东西
也有用到 synchronized method 或是 lock 之类的东西
当然有程式有包含错误处理(try catch),目前使用没遇到状况
不过主管对程式有些看法是我不能理解的,以下模拟对话内容
主管: 万一Thread消失怎么办?
cyclone350: 消失? Thread 本身如果有错误,有 try catch 作错误处理
Thread 执行最外层也有执行错误处理 (送 mail, 写 log 之类的)
主管: 不,我是说 Thread 消失了,try catch 也不会知道,但是你的程式
却正常执行。
cyclone350: ......?
主管: 你要怎么确保Thread不会消失? 或是让Thread消失后可以被侦测到?
cyclone350: ...? 若 Thread 发生错误,有错误处理,我不了解消失是...?
主管: 就是Thread消失了,但是JVM没发觉,程式却正常执行的情况
cyclone350: ......? 如果 Thread 从系统里蒸发.. 而JVM却没察觉的话...
我的错误处理并没有防堵这种状况....
主管: 必须想出一种机制能够让别人知道程式是正常运作的