Java的多线程和线程池的使用,你真的清楚了吗?
Java的多線程和線程池的使用
多線程大大提高程序運(yùn)行效率,我們在開發(fā)過程中經(jīng)常會(huì)開啟一個(gè)線程來執(zhí)行一些費(fèi)時(shí)的任務(wù)。開啟一個(gè)線程有4種方式,在下面的文章我將詳細(xì)的去講解。
繼承Thread
繼承Thread去執(zhí)行任務(wù),確實(shí)可以開啟一個(gè)線程去執(zhí)行任務(wù),如果經(jīng)常的去開啟一些線程,也會(huì)導(dǎo)致系統(tǒng)資源的浪費(fèi)。
實(shí)現(xiàn)Runnale接口。
public static class MyRunable implements Runnable { @Override public void run() { System.out.println("當(dāng)前線程"+Thread.currentThread().getId()); int i = 10/2; System.out.println("運(yùn)行結(jié)果"+i); } }調(diào)用。
/** * runable的啟動(dòng)方式 */ MyRunable runable = new MyRunable(); new Thread(runable).start(); System.out.println("main--end");Callable
/** * Callable可以允許有返回值 */ public static class Callale01 implements Callable<Integer> { @Override public Integer call() throws Exception { System.out.println("當(dāng)前線程"+Thread.currentThread().getId()); int i = 10/2; System.out.println("運(yùn)行結(jié)果"+i); return i; } }調(diào)用。這里需要用callable構(gòu)建futureTask
/** * callale的啟動(dòng)方式 */ 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)資源。通常我們會(huì)將下面的一些配置寫在一些配置類中
常見的4種線程池。
1 newCachedThreadPool()
創(chuàng)建一個(gè)可緩存的線程池,如果線程池長度超過了處理的需要,可靈活的回收空閑線程。若無可回收。則創(chuàng)建新線程。
2.newFixedThreadPool(6)
創(chuàng)建一個(gè)固定大小的線程池。
3 newScheduledThreadPool()
定時(shí)任務(wù)的線程池。
4.newSingleThreadExecutor()
Executors.newSingleThreadExecutor();記得多多支持Remi醬!!
文章來源:https://www.tuicool.com/articles/YNbyayI
總結(jié)
以上是生活随笔為你收集整理的Java的多线程和线程池的使用,你真的清楚了吗?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java后端架构开荒实战(二)——单机到
- 下一篇: 你真的弄明白了吗?Java并发之AQS详