Java線程的三種創(chuàng)建方式
1、Thread
繼承Thread
類,并重寫run
方法
class ThreadDemo1 extends Thread { @Override public void run() { log.info("{}", Thread.currentThread().getName()); } }
線程啟動(dòng)方式:
ThreadDemo1 t1 = new ThreadDemo1(); t1.setName("t1"); t1.start();
簡(jiǎn)便寫法:
Thread t1 = new Thread() { @Override public void run() { log.info("{}", Thread.currentThread().getName()); } }; t1.setName("t1"); t1.start();
2、Runnable和Thread
Thread
類的構(gòu)造函數(shù)支持傳入Runnable
的實(shí)現(xiàn)類
public Thread(Runnable target) { init(null, target, "Thread-" + nextThreadNum(), 0); } Thread(Runnable target, AccessControlContext acc) { init(null, target, "Thread-" + nextThreadNum(), 0, acc, false); }
Runnable
是一個(gè)函數(shù)式接口(FunctionalInterface
)
@FunctionalInterface public interface Runnable { // 沒(méi)有返回值 public abstract void run(); }
因此需要?jiǎng)?chuàng)建類實(shí)現(xiàn)Runnable
接口,重寫run
方法
class ThreadDemo2 implements Runnable { @Override public void run() { log.info("{}", Thread.currentThread().getName()); } }
簡(jiǎn)便寫法:
Thread t2 = new Thread(() -> log.info("{}", Thread.currentThread().getName()), "t2"); t2.start();
3、Runnable和Thread
Callable
和Runnable
一樣,也是一個(gè)函數(shù)式接口,二者的區(qū)別非常明顯,Runnable
中run
方法沒(méi)有返回值,Callable
中的run
方法有返回值(可以通過(guò)泛型約束返回值類型)。因此在需要獲取線程執(zhí)行的返回值時(shí),可以使用Callable
。
@FunctionalInterface public interface Callable<V> { // 帶返回值 V call() throws Exception; }
在Thread
的構(gòu)造函數(shù)中,并沒(méi)有看到Callable
,只有Runnable
此時(shí)需要一個(gè)可以提交Callable給Thread的類,這類就是FutureTask;FutureTask實(shí)現(xiàn)類Runnable接口。
并且FutureTask
提供了傳入Callable
的構(gòu)造函數(shù)
public FutureTask(Callable<V> callable) { if (callable == null) throw new NullPointerException(); this.callable = callable; this.state = NEW; // ensure visibility of callable }
因此可以通過(guò)FutureTask傳入Callable實(shí)現(xiàn),再將FutureTask傳給Thread即可
ThreadDemo3 implements Callable<Integer> { @Override public Integer call() throws Exception { log.info("{}", Thread.currentThread().getName()); return 1998; } }
// Callable 實(shí)現(xiàn)類 ThreadDemo3 callable = new ThreadDemo3(); // 通過(guò)Callable創(chuàng)建FutureTask FutureTask<Integer> task = new FutureTask(callable); // 通過(guò)FutureTask創(chuàng)建Thread Thread t3 = new Thread(task, "t3"); t3.start();
簡(jiǎn)便寫法:
Thread t3 = new Thread(new FutureTask<Integer>(() -> { log.info("{}", Thread.currentThread().getName()); return 1998; }), "t3"); t3.start();
4、三者對(duì)比
創(chuàng)建線程的方式有三種:
Thread
、Runnable+Thread
、Callable+FutureTask+Thread
;這三者如何選擇呢?
- 首先在實(shí)際的開(kāi)發(fā)過(guò)程中,我們不會(huì)直接創(chuàng)建線程,因?yàn)轭l繁創(chuàng)建和銷毀線程開(kāi)銷比較大,此外不利于管理和釋放,因此項(xiàng)目中都是通過(guò)設(shè)計(jì)線程池來(lái)管理線程資源
Thread
、Runnable+Thread
相比,Runnable+Thread
將線程的創(chuàng)建和任務(wù)模塊解耦了,代碼設(shè)計(jì)更加靈活,此外更加利于任務(wù)的提交,更方便和線程池結(jié)合使用Callable+FutureTask+Thread
適用于需要獲取線程返回結(jié)果的場(chǎng)景
5、注意項(xiàng)
文中多次使用thread.start()
;需要注意的是,調(diào)用線程的start()
方法表示啟動(dòng)線程,但是線程是否執(zhí)行并不確定,這需要操作系統(tǒng)調(diào)度,線程分配到CPU執(zhí)行時(shí)間片才能執(zhí)行。多核CPU下多個(gè)線程同時(shí)啟動(dòng),線程之間交替執(zhí)行,執(zhí)行順序是不確定的。
到此這篇關(guān)于Java線程的三種創(chuàng)建方式的文章就介紹到這了,更多相關(guān)Java線程創(chuàng)建方式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java調(diào)用外接設(shè)備詳解(制卡機(jī))
這篇文章主要為大家詳細(xì)介紹了Java調(diào)用外接設(shè)備的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07在攔截器中讀取request參數(shù),解決在controller中無(wú)法二次讀取的問(wèn)題
這篇文章主要介紹了在攔截器中讀取request參數(shù),解決在controller中無(wú)法二次讀取的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Java 8 Stream 的終極技巧——Collectors 功能與操作方法詳解
這篇文章主要介紹了Java 8 Stream Collectors 功能與操作方法,結(jié)合實(shí)例形式詳細(xì)分析了Java 8 Stream Collectors 功能、操作方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2020-05-05Java實(shí)現(xiàn)簡(jiǎn)單抽獎(jiǎng)功能界面
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)單抽獎(jiǎng)功能界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11Java開(kāi)發(fā)編程到底是用idea好還是eclipse好
這篇文章主要介紹了Java開(kāi)發(fā)編程到底是用idea好還是eclipse好,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08spring data jpa開(kāi)啟批量插入、批量更新的問(wèn)題解析
這篇文章主要介紹了spring data jpa開(kāi)啟批量插入、批量更新問(wèn)題,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07SpringBoot?實(shí)現(xiàn)CAS?Server統(tǒng)一登錄認(rèn)證的詳細(xì)步驟
??CAS(Central?Authentication?Service)中心授權(quán)服務(wù),是一個(gè)開(kāi)源項(xiàng)目,目的在于為Web應(yīng)用系統(tǒng)提供一種可靠的單點(diǎn)登錄,這篇文章主要介紹了SpringBoot?實(shí)現(xiàn)CAS?Server統(tǒng)一登錄認(rèn)證,需要的朋友可以參考下2024-02-02Nacos下線服務(wù)時(shí),下線報(bào)錯(cuò)選舉Leader失敗問(wèn)題以及解決
這篇文章主要介紹了Nacos下線服務(wù)時(shí),下線報(bào)錯(cuò)選舉Leader失敗問(wèn)題以及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07