一個需求:要實現能重啟的線程。
背景:要啟動一個線程,通過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重啟"); } }