R君今天曾問我:假設現在有三個線程T1、T2、T3。那么他希望T1、T2、T3這三個線程按照順序去執行,該怎么去完成。我本能的反應是這個好辦,使用thread.jon()方法完全可以實現。接着他又問,有沒有其它的實現方式,這時我在想,線程的優先級呢,為這三個線程設置優先級,但是我隨之否定了自己的這個想法,因為線程的優先級只是理論上的優先級,它可以讓線程優先級高的可能概率稍微大的先執行,但是具體執行哪一個線程卻是由電腦控制的。眾所周知,計算機對於線程的執行是搶占式策略,誰能搶到誰先執行,因此這個方案並不能完全控制順序。
先說我使用join()方法來實現的具體過程吧;關於join()方法,假設A線程去調用B線程的join()方法,那么只有等待B線程完全執行完畢,A線程才可以執行。具體原理是在A線程中調用B線程的Join()方法,相當於A線程調用了B線程的wait()方法,那么只用當B線程執行完畢,A才會執行,這個期間A線程進入阻塞狀態。看如下的實現:
這種方式是在啟動線程的時候去順序的控制。使得並行執行的任務串行化的執行。下面的一種實現方式還是使用的join()方法,但是不同的地方在於下述的方法是在線程的內部進行控制的,其本質和第一種相同。
(這篇文章是我從自己的微信公眾號上粘貼過來的)
在這里我吐槽下微信公眾號這個編輯器真的很糟心。尤其是對於程序猿來說,沒有markdown編輯器,文章的排版太不友好。代碼我只能貼圖片,否則根本不忍直視。
在上述的例子中驗證的結果我沒有貼出,但是保證了順序執行。下面的一種方法是我參照網上的博文的實現,線程池的實現。定義一個創建單個線程的線程池,所有的任務會存儲在一個阻塞隊列中,隊列遵從FIFO原則,即先進先出的原則。這樣也可以保證執行順序。
創建一個newSingleThreadExecutor的線程池。雖然保證了實現,但是任務的提交時有順序的,先提交的是t1,然后t2、t3這種方式。任務的執行存在順序。
第一次使用公眾號記錄自己日常的一些技術問題,希望能和大家多多交流。最后我再提一個實現的想法,就是雖然三個線程,但是對比多線程的生產者和消費者模型來看,只多了一個線程,不知道能不能使用這種模型實現,這位如果有好的實現也可以分享下。Best Regards!
最后再推薦下自己的微信公眾號