一個需求:要實現能重啟的線程。
背景:要啟動一個線程,通過zmq,不斷接收放過來的消息,在通知相應的用戶。
假如這個時候網絡不好或者其他問題,崩潰了,怎么辦。當然,第一時間想到了try catch。
但是try catch沒用啊。雖然沒影響到項目的運行,但是這個線程報了異常之后就不會再執行了,這個訂閱和通知功能就沒有了。
所以要實現一個,崩潰了可以重新啟動的線程了。
解決:用到了java自帶的觀察者模式。
被觀察者拋出異常的時候,通知觀察者。然后觀察者直接給它重啟就好了。也不存在觀察者猝死的情況。
被觀察者 Observable
public class RunThread extends Observableimplements Runnable{
// 此方法一經調用,立馬可以通知觀察者,在本例中是監聽線程
publicvoid doBusiness(){
if(true){
super.setChanged();
}
notifyObservers();
}
@Override
publicvoid run() {
intc = 0;
while(true){ //模擬線程運行一段時間之后退出
System.out.println("Runing- "+c+" "+DateUtil.getStdDateTime());
try{
Thread.sleep(2000);
}catch (InterruptedException e) {
e.printStackTrace();
doBusiness();
break;
}
c++;
//模擬拋出異常
try{
if(c== 4){
Stringstr = null;
str.length();//此處將會拋出空指針異常
}
}catch (Exception e) {
e.printStackTrace();
doBusiness();//在拋出異常時調用,通知觀察者,讓其重啟線程
break;//異常拋出之后,一定要跳出循環,保證將線程送進地獄
}
}
}
publicstatic void main(String[] args) {
RunThreadrun = new RunThread();
Listener listen = new Listener();
un.addObserver(listen);
newThread(run).start();
//run.doBusiness();
}
}
觀察者 Observer
public class Listener implements Observer{
@Override
publicvoid update(Observable o, Object arg) {
System.out.println("RunThread死機");
RunThreadrun = new RunThread();
run.addObserver(this);
newThread(run).start();
System.out.println("RunThread重啟");
}
}
