Java線程中start和run方法全面解析
自定義線程兩種方法
自定義一個runnable接口的實現(xiàn)類,然后構(gòu)造一個thread,即對thread傳入一個runnable接口類。
new一個thread或者寫個thread子類,覆蓋它的run方法。(new 一個thread并覆蓋run方法實際上是匿名內(nèi)部類的一種方式)
示例代碼
public static void main(String[] args) { new Thread(new Runnable() { @Override public void run() { System.out.println("create thread by passing a runnable target !"); } }).start(); new Thread(){ @Override public void run() { System.out.println("create thread by Override run method !"); }; }.start(); }
上述對應(yīng)1和2兩種構(gòu)造線程的方法,由于代碼寫法設(shè)計匿名類對象,現(xiàn)做如下輔助說明:
1. 對于第一段我直接傳入了匿名runnable實例,可以自定義一個runnable實例,然后new thread(runnable)這種形式獲得thread;
2. 對于第二段可以專門定義一個class去extends thread基類,然后new 這個新的線程類。
3. 對于這兩段都是直接new thread 創(chuàng)建匿名類對象,可以定義一個變量thread1、thread2,然后利用thread1.start() thread2.start()啟動線程;
源碼剖析
這兩種方式有什么區(qū)別呢,二者最終效果是一樣的,源代碼級別來看,thread的默認的run方法(不被覆寫的話)是調(diào)用target(target不為空的話)的run方法,target就是我們傳入的runnable接口類。
public synchronized void start() { if (threadStatus != 0) throw new IllegalThreadStateException(); group.add(this); boolean started = false; try { start0(); started = true; } finally { try { if (!started) { group.threadStartFailed(this); } } catch (Throwable ignore) { } } }
線程的start最終會調(diào)用native的start0,此方法會使得jvm虛擬機調(diào)用線程的run方法。
public void run() { if (target != null) { target.run(); } }
這里的target是一個Thread中的runnable的對象
private Runnable target;
總結(jié)
復(fù)寫thread的run方法,則就是start的時候線程去執(zhí)行的run方法。
傳入runnable,則start的時候線程執(zhí)行默認run方法,run方法中會對傳入的target進行調(diào)用,調(diào)用target的run方法。
兩者效果一樣,這里只是幫助我們?nèi)タ创a細節(jié)差異。
以上所述是小編給大家介紹的Java線程中start和run方法全面解析,希望對大家有所幫助,如果大家想了解更多內(nèi)容敬請關(guān)注腳本之家!
相關(guān)文章
Win10系統(tǒng)下配置java環(huán)境變量的全過程
這篇文章主要給大家介紹了關(guān)于Win10系統(tǒng)下配置java環(huán)境變量的相關(guān)資料,文中通過圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11SpringBoot如何使用Undertow做服務(wù)器
這篇文章主要介紹了SpringBoot如何使用Undertow做服務(wù)器,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07