Android ThreadPool匀油、AsyncTask、Future勾笆、FutureTask敌蚜、Callable和Runable

使用多線程用new Thread():
1.多任務(wù)情況下,避免線程頻繁的創(chuàng)建銷毀窝爪;
2.多個(gè)線程頻繁的創(chuàng)建會(huì)占用大量的資源弛车,并且在資源競(jìng)爭(zhēng)的時(shí)候出現(xiàn)問(wèn)題,缺乏統(tǒng)一的管理蒲每,容易造成線程卡頓纷跛;
3.多個(gè)線程頻繁銷毀,會(huì)頻繁調(diào)用GC機(jī)制邀杏,降低性能并且耗時(shí)忽舟;
線程池的作用:
1.對(duì)線程統(tǒng)一管理,避免資源競(jìng)爭(zhēng)造成卡頓淮阐、死機(jī)等問(wèn)題叮阅;
2.對(duì)線程服用,不會(huì)在線程結(jié)束后立即銷毀泣特,等待其他任務(wù)浩姥。避免了頻繁創(chuàng)建、銷毀和調(diào)用GC機(jī)制

public class ThreadPool {
    ThreadPoolExecutor mThreadPoolExecutor;

    private int corePoolSize;
    private int maximumPoolSize;
    private long keepAliveTime;

    private static ThreadPool mThreadPool = null;

    public static ThreadPool getInstance() {
        if (mThreadPool == null) {
            synchronized (ThreadPool.class){
                mThreadPool = new ThreadPool(5, 10, 5 * 1000);
            }
        }
        return mThreadPool;
    }

    private ThreadPool(int corePoolSize, int maximumPoolSize, long keepAliveTime) {
        this.corePoolSize = corePoolSize;
        this.maximumPoolSize = maximumPoolSize;
        this.keepAliveTime = keepAliveTime;
    }

    private ThreadPoolExecutor initExecutor() {
        if (mThreadPoolExecutor == null) {
            synchronized (ThreadPool.class) {
                if (mThreadPoolExecutor == null) {

                    TimeUnit unit = TimeUnit.MILLISECONDS;
                    ThreadFactory threadFactory = Executors.defaultThreadFactory();
                    RejectedExecutionHandler handler = new ThreadPoolExecutor.AbortPolicy();
                    LinkedBlockingQueue<Runnable> workQueue = new LinkedBlockingQueue<>();

                    mThreadPoolExecutor = new ThreadPoolExecutor(
                            corePoolSize,//核心線程數(shù)
                            maximumPoolSize,//最大線程數(shù)
                            keepAliveTime,//保持時(shí)間
                            unit,//保持時(shí)間對(duì)應(yīng)的單位
                            workQueue,
                            threadFactory,//線程工廠
                            handler);//異常捕獲器
                }
            }
        }
        return mThreadPoolExecutor;
    }


    /**
     * 執(zhí)行任務(wù)
     */
    public void executeTask(Runnable r) {
        initExecutor();
        mThreadPoolExecutor.execute(r);
    }


    /**
     * 提交任務(wù)
     */
    public Future<?> commitTask(Runnable r) {
        initExecutor();
        return mThreadPoolExecutor.submit(r);
    }

    /**
     * 刪除任務(wù)
     */
    public void removeTask(Runnable r) {
        initExecutor();
        mThreadPoolExecutor.remove(r);
    }

}

FutureTask
FutureTask是實(shí)現(xiàn)了future的Runable状您,F(xiàn)utureTask比Runable多了一個(gè)執(zhí)行的返回值

 private void test(){

        AsyncTask<Boolean,String,Integer> asyncTask = new AsyncTask<Boolean, String, Integer>() {

            @Override
            protected Integer doInBackground(Boolean... booleans) {
                return null;
            }

            @Override
            protected void onPreExecute() {
                super.onPreExecute();
            }

            @Override
            protected void onPostExecute(Integer integer) {
                super.onPostExecute(integer);
            }

            @Override
            protected void onProgressUpdate(String... values) {
                super.onProgressUpdate(values);
            }

            @Override
            protected void onCancelled(Integer integer) {
                super.onCancelled(integer);
            }

            @Override
            protected void onCancelled() {
                super.onCancelled();
            }
        };
        asyncTask.execute();
        asyncTask.getStatus();

        Callable<Boolean> callable = new Callable<Boolean>() {
            @Override
            public Boolean call() throws Exception {
                return false;
            }
        };
        FutureTask futureTask = new FutureTask(callable );
        futureTask.cancel(true);

        ThreadPoolExecutor poolExecutor = new ThreadPoolExecutor(
                2,10,300,
                TimeUnit.MICROSECONDS,new LinkedBlockingDeque<Runnable>(),
                Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());
        Future<Boolean> future= poolExecutor.submit(callable);
        future.cancel(true);
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末勒叠,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子膏孟,更是在濱河造成了極大的恐慌眯分,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件柒桑,死亡現(xiàn)場(chǎng)離奇詭異弊决,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門飘诗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)与倡,“玉大人,你說(shuō)我怎么就攤上這事昆稿》淖” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵溉潭,是天一觀的道長(zhǎng)净响。 經(jīng)常有香客問(wèn)我,道長(zhǎng)喳瓣,這世上最難降的妖魔是什么馋贤? 我笑而不...
    開封第一講書人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮夫椭,結(jié)果婚禮上掸掸,老公的妹妹穿的比我還像新娘。我一直安慰自己蹭秋,他們只是感情好扰付,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著仁讨,像睡著了一般羽莺。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上洞豁,一...
    開封第一講書人閱讀 51,231評(píng)論 1 299
  • 那天盐固,我揣著相機(jī)與錄音,去河邊找鬼丈挟。 笑死刁卜,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的曙咽。 我是一名探鬼主播蛔趴,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼例朱!你這毒婦竟也來(lái)了孝情?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤洒嗤,失蹤者是張志新(化名)和其女友劉穎箫荡,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體渔隶,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡羔挡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片婉弹。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡睬魂,死狀恐怖终吼,靈堂內(nèi)的尸體忽然破棺而出镀赌,到底是詐尸還是另有隱情,我是刑警寧澤际跪,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布商佛,位于F島的核電站,受9級(jí)特大地震影響姆打,放射性物質(zhì)發(fā)生泄漏良姆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一幔戏、第九天 我趴在偏房一處隱蔽的房頂上張望玛追。 院中可真熱鬧,春花似錦闲延、人聲如沸痊剖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)陆馁。三九已至,卻和暖如春合愈,著一層夾襖步出監(jiān)牢的瞬間叮贩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工佛析, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留益老,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓寸莫,卻偏偏與公主長(zhǎng)得像捺萌,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子储狭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 一:使用線程池的原因 在android開發(fā)中經(jīng)常會(huì)使用多線程異步來(lái)處理相關(guān)任務(wù)互婿,而如果用傳統(tǒng)的newThread來(lái)...
    無(wú)問(wèn)o閱讀 81,652評(píng)論 18 141
  • 線程 線程在Android中是個(gè)很重要的概念,從用途來(lái)說(shuō)辽狈,線程分為主線程與子線程慈参,主線程用于處理界面相關(guān)事情,子線...
    我好芒閱讀 29,067評(píng)論 0 34
  • 1 線程池簡(jiǎn)介 線程池指的是ThreadPoolExecutor刮萌,它實(shí)現(xiàn)了ExecutorService接口驮配,并封...
    秀葉寒冬閱讀 896評(píng)論 0 3
  • 一、為什么使用線程池1.線程池吃好處(1).對(duì)多個(gè)線程進(jìn)行統(tǒng)一管理,避免資源競(jìng)爭(zhēng)中出現(xiàn)問(wèn)題(2).(重點(diǎn))對(duì)線程進(jìn)...
    思思入扣閱讀 198評(píng)論 0 0
  • 以米燕的成長(zhǎng)軌跡為主線壮锻,寫在大山里長(zhǎng)大的60后琐旁、70后女孩的命運(yùn)。 上一章 福兮禍也 大概一個(gè)月之后猜绣,陳老師托一位...
    沐兒閱讀 1,383評(píng)論 26 22