多線程串行執(zhí)行

1.直接使用線程池:

對(duì)線程池不熟悉的可以看我另外一篇博客。上一篇的代碼這一篇也有用到。線程池簡(jiǎn)介

 /**
     * 串行執(zhí)行多線程任務(wù)  第一種 使用線程池
     */

    //任務(wù)隊(duì)列瓮栗。android 提供有:LinkedBlockingQueue ArrayQueue ArrayBlockQueue 區(qū)別自己百度吧。
    LinkedBlockingQueue<Runnable> workQueue = new LinkedBlockingQueue<>(100);
    //線程工廠
    ThreadFactory threadFactory = new ThreadFactory(){
        @Override
        public Thread newThread(@NonNull Runnable r) {
            return new Thread(r);
        }
    };
    //設(shè)置一個(gè)核心線程數(shù)為1瞄勾,最大線程數(shù)為5遵馆,任務(wù)隊(duì)列最大容量為100,閑置關(guān)閉時(shí)間為1秒的線程池
    ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(1, 5, 1l, java.util.concurrent.TimeUnit.SECONDS, workQueue, threadFactory);

    public void executeByExecutor(Runnable runnable){
        threadPoolExecutor.execute(runnable);
    }

<img src="https://upload-images.jianshu.io/upload_images/13400445-50bccacbeba69c7d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" width="500" height="313" align=center/>

Screenshot_2018-09-14-16-47-03.png

任務(wù)升級(jí):我有時(shí)想串行丰榴,有時(shí)想并行货邓。

沒(méi)必要?jiǎng)?chuàng)建兩個(gè)線程池。我們直接用一個(gè)線程池就能實(shí)現(xiàn)四濒。

public class MyQueueAndThreadPool {


    private final ThreadPoolExecutor threadPoolExecutor;
    private ArrayDeque<Runnable> mTasks;
    private Runnable mActive;

    public MyQueueAndThreadPool(){
        mTasks = new ArrayDeque<>();
        ThreadFactory threadFactory = new ThreadFactory() {
            @Override
            public Thread newThread(@NonNull Runnable r) {

                return new Thread(r);
            }
        };
         ;
        threadPoolExecutor = new ThreadPoolExecutor(5, 10, 60, java.util.concurrent.TimeUnit.SECONDS, new LinkedBlockingDeque<Runnable>(), threadFactory);
    }

    public void execute(final Runnable r){

        mTasks.offer(new Runnable() {
            @Override
            public void run() {
                r.run();
                doOnNext();
            }
        });
        //第一個(gè)進(jìn)去换况,啟動(dòng)這個(gè)循環(huán)职辨。
        if(mActive == null){
            doOnNext();
        }

    }

    public void executeOnExecutor(Runnable r){
        threadPoolExecutor.execute(r);
    }

    private void doOnNext(){
        if((mActive = mTasks.poll())!=null){
            threadPoolExecutor.execute(mActive);
        };
    }
}

//執(zhí)行。
//                executeByExecutor(runnable);
//                executeByExecutor(runnable_2);
//                executeByExecutor(runnable_3);
                myQueueAndThreadPool.executeOnExecutor(runnable);
                myQueueAndThreadPool.executeOnExecutor(runnable_2);
                myQueueAndThreadPool.executeOnExecutor(runnable_3);
[圖片上傳中...(Screenshot_2018-09-17-10-55-12.png-b6988c-1537153273421-0)]
Screenshot_2018-09-17-10-55-12.png

其實(shí)這里就是asyncTask的內(nèi)部邏輯戈二。只是asyncTask同時(shí)考慮了異常和線程同步的問(wèn)題舒裤,我這里只是簡(jiǎn)單實(shí)現(xiàn)了一下原理。觉吭。腾供。

3.使用wait和notify

public class ThreadSerialzetow {


    public static void main(String[] args){

        ThreadA threadA = new ThreadA();
        ThreadB threadB = new ThreadB();
        ThreadC threadC = new ThreadC();

        threadA.add(threadC);
        threadB.add(threadA);
        threadC.add(threadB);
        threadA.start();
        threadB.start();
        threadC.start();
    }

    static class ThreadA extends Thread{
        public ThreadC threadc;
        @Override
        public void run() {
            while (true){


            synchronized(threadc){
                synchronized(this){
                    System.out.println("我是A");
                    this.notify();
                }

                try {
                    threadc.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }


            }

        }
        }
        public void add(ThreadC th){
            threadc = th;
        }
    }
    static class ThreadB extends Thread{
        public ThreadA threada;
        @Override
        public void run() {
            while(true){


            synchronized(threada){
                synchronized(this){
                    System.out.println("我是B");
                    this.notify();
                }
                try {
                    threada.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            }
        }
        public void add(ThreadA th){
            threada = th;
        }
    }
    static class ThreadC extends Thread{
        public ThreadB threadb;
        @Override
        public void run() {
            while(true){


            synchronized(threadb){
                synchronized(this){
                    System.out.println("我是C");
                    this.notify();
                }
                try {
                    threadb.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }


        }
        }
        public void add(ThreadB th){
            threadb = th;
        }
    }
}

這段代碼不是我寫(xiě)的。是在網(wǎng)上找的鲜滩。運(yùn)行起來(lái)可以實(shí)現(xiàn)a>b>c順序無(wú)限執(zhí)行伴鳖,有時(shí)可能會(huì)死鎖,有時(shí)會(huì)出現(xiàn)a>c>b然后轉(zhuǎn)為a>b>c徙硅。其中玄妙自己體會(huì)吧榜聂。。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嗓蘑,一起剝皮案震驚了整個(gè)濱河市须肆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌桩皿,老刑警劉巖豌汇,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異泄隔,居然都是意外死亡拒贱,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)梅尤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)柜思,“玉大人,你說(shuō)我怎么就攤上這事巷燥∩呐蹋” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵缰揪,是天一觀的道長(zhǎng)陨享。 經(jīng)常有香客問(wèn)我,道長(zhǎng)钝腺,這世上最難降的妖魔是什么抛姑? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮艳狐,結(jié)果婚禮上定硝,老公的妹妹穿的比我還像新娘。我一直安慰自己毫目,他們只是感情好蔬啡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布诲侮。 她就那樣靜靜地躺著,像睡著了一般箱蟆。 火紅的嫁衣襯著肌膚如雪沟绪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,754評(píng)論 1 307
  • 那天空猜,我揣著相機(jī)與錄音绽慈,去河邊找鬼。 笑死辈毯,一個(gè)胖子當(dāng)著我的面吹牛坝疼,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播漓摩,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼裙士,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼入客!你這毒婦竟也來(lái)了管毙?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤桌硫,失蹤者是張志新(化名)和其女友劉穎夭咬,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體铆隘,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡卓舵,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了膀钠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掏湾。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖肿嘲,靈堂內(nèi)的尸體忽然破棺而出融击,到底是詐尸還是另有隱情,我是刑警寧澤雳窟,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布尊浪,位于F島的核電站,受9級(jí)特大地震影響封救,放射性物質(zhì)發(fā)生泄漏拇涤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一誉结、第九天 我趴在偏房一處隱蔽的房頂上張望鹅士。 院中可真熱鬧,春花似錦惩坑、人聲如沸掉盅。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)怔接。三九已至搪泳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間扼脐,已是汗流浹背岸军。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瓦侮,地道東北人艰赞。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像肚吏,于是被迫代替她去往敵國(guó)和親方妖。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355