您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)java中多線程與線程池怎么用的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
繼承Thread去執(zhí)行任務(wù),確實可以開啟一個線程去執(zhí)行任務(wù),如果經(jīng)常的去開啟一些線程,也會導(dǎo)致系統(tǒng)資源的浪費。
public static class Mythread extends Thread{ @Override public void run() { System.out.println("當前線程"+Thread.currentThread().getId()); int i = 10/2; System.out.println("運行結(jié)果"+i); } } //調(diào)用線程。 public static void main(String[] args) throws ExecutionException, InterruptedException { /**thread執(zhí)行方式*/ Mythread mythread = new Mythread(); mythread.start();//啟動線程 System.out.println("main--end"); }
public static class MyRunable implements Runnable { @Override public void run() { System.out.println("當前線程"+Thread.currentThread().getId()); int i = 10/2; System.out.println("運行結(jié)果"+i); } }
調(diào)用。
/** * runable的啟動方式 */ MyRunable runable = new MyRunable(); new Thread(runable).start(); System.out.println("main--end");
/** * Callable可以允許有返回值 */ public static class Callale01 implements Callable<Integer> { @Override public Integer call() throws Exception { System.out.println("當前線程"+Thread.currentThread().getId()); int i = 10/2; System.out.println("運行結(jié)果"+i); return i; } }
調(diào)用。這里需要用callable構(gòu)建futureTask
/** * callale的啟動方式 */ FutureTask<Integer> futureTask =new FutureTask<>(new Callale01()); //取返回結(jié)果。 Integer i = futureTask.get(); new Thread(futureTask).start(); System.out.println("返回結(jié)果是:"+i);
線程池才是我們java開發(fā)中,經(jīng)常用到一種開啟多線程的方式,線程池,自己去管理線程??梢怨?jié)省系統(tǒng)資源。通常我們會將下面的一些配置寫在一些配置類中
/** * 七大參數(shù) * corePoolSize: 1.核心線程數(shù)[一直存在]: 線程池創(chuàng)建好了以后。就準備就緒的線程數(shù)量。 * maxinumPoolSize: 2 最大線程數(shù)量 * keepaliveTime: 存活時間。空閑線程的最大的等待時間。 * unit 等待時間的單位 * blockingQueue 阻塞隊列。如果任務(wù)很多就會放在隊列里面,只要有線程空閑了,就會去隊列里面去取。 * threadFactory :線程的工廠。 * RejectExecutionHandler :如果隊列滿了。按照我們指定的策略。拒絕執(zhí)行任務(wù)。 * */ ThreadPoolExecutor executor = new ThreadPoolExecutor(5,100,10,TimeUnit.SECONDS, new LinkedBlockingQueue<>(100), Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());
1 newCachedThreadPool()
創(chuàng)建一個可緩存的線程池,如果線程池長度超過了處理的需要,可靈活的回收空閑線程。若無可回收。則創(chuàng)建新線程。
Executors.newCachedThreadPool();
2.newFixedThreadPool(6)
創(chuàng)建一個固定大小的線程池。
3 newScheduledThreadPool()
定時任務(wù)的線程池。
4.newSingleThreadExecutor()
Executors.newSingleThreadExecutor();
感謝各位的閱讀!關(guān)于“java中多線程與線程池怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。