您好,登錄后才能下訂單哦!
小編給大家分享一下java中創(chuàng)建線程的方法有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
java中創(chuàng)建線程的三種方法是:1、繼承Thread類創(chuàng)建線程;2、實(shí)現(xiàn)Runnable接口創(chuàng)建線程;3、使用Callable和Future創(chuàng)建線程。
Java使用Thread類代表線程,所有的線程對(duì)象都必須是Thread類或其子類的實(shí)例。Java可以用三種方式來創(chuàng)建線程,如下所示:
1)繼承Thread類創(chuàng)建線程
2)實(shí)現(xiàn)Runnable接口創(chuàng)建線程
3)使用Callable和Future創(chuàng)建線程
下面讓我們分別來看看這三種創(chuàng)建線程的方法。
------------------------繼承Thread類創(chuàng)建線程---------------------
通過繼承Thread類來創(chuàng)建并啟動(dòng)多線程的一般步驟如下
1】d定義Thread類的子類,并重寫該類的run()方法,該方法的方法體就是線程需要完成的任務(wù),run()方法也稱為線程執(zhí)行體。
2】創(chuàng)建Thread子類的實(shí)例,也就是創(chuàng)建了線程對(duì)象
3】啟動(dòng)線程,即調(diào)用線程的start()方法
代碼實(shí)例
public class MyThread extends Thread{//繼承Thread類 public void run(){ //重寫run方法 } } public class Main { public static void main(String[] args){ new MyThread().start();//創(chuàng)建并啟動(dòng)線程 } }
------------------------實(shí)現(xiàn)Runnable接口創(chuàng)建線程---------------------
通過實(shí)現(xiàn)Runnable接口創(chuàng)建并啟動(dòng)線程一般步驟如下:
1】定義Runnable接口的實(shí)現(xiàn)類,一樣要重寫run()方法,這個(gè)run()方法和Thread中的run()方法一樣是線程的執(zhí)行體
2】創(chuàng)建Runnable實(shí)現(xiàn)類的實(shí)例,并用這個(gè)實(shí)例作為Thread的target來創(chuàng)建Thread對(duì)象,這個(gè)Thread對(duì)象才是真正的線程對(duì)象
3】第三部依然是通過調(diào)用線程對(duì)象的start()方法來啟動(dòng)線程
代碼實(shí)例:
public class MyThread2 implements Runnable {//實(shí)現(xiàn)Runnable接口 public void run(){ //重寫run方法 } } public class Main { public static void main(String[] args){ //創(chuàng)建并啟動(dòng)線程 MyThread2 myThread=new MyThread2(); Thread thread=new Thread(myThread); thread().start(); //或者 new Thread(new MyThread2()).start(); } }
------------------------使用Callable和Future創(chuàng)建線程---------------------
和Runnable接口不一樣,Callable接口提供了一個(gè)call()方法作為線程執(zhí)行體,call()方法比run()方法功能要強(qiáng)大。
》call()方法可以有返回值
》call()方法可以聲明拋出異常
Java5提供了Future接口來代表Callable接口里call()方法的返回值,并且為Future接口提供了一個(gè)實(shí)現(xiàn)類FutureTask,這個(gè)實(shí)現(xiàn)類既實(shí)現(xiàn)了Future接口,還實(shí)現(xiàn)了Runnable接口,因此可以作為Thread類的target。在Future接口里定義了幾個(gè)公共方法來控制它關(guān)聯(lián)的Callable任務(wù)。
>boolean cancel(boolean mayInterruptIfRunning):視圖取消該Future里面關(guān)聯(lián)的Callable任務(wù)
>V get():返回Callable里call()方法的返回值,調(diào)用這個(gè)方法會(huì)導(dǎo)致程序阻塞,必須等到子線程結(jié)束后才會(huì)得到返回值
>V get(long timeout,TimeUnit unit):返回Callable里call()方法的返回值,最多阻塞timeout時(shí)間,經(jīng)過指定時(shí)間沒有返回拋出TimeoutException
>boolean isDone():若Callable任務(wù)完成,返回True
>boolean isCancelled():如果在Callable任務(wù)正常完成前被取消,返回True
介紹了相關(guān)的概念之后,創(chuàng)建并啟動(dòng)有返回值的線程的步驟如下:
1】創(chuàng)建Callable接口的實(shí)現(xiàn)類,并實(shí)現(xiàn)call()方法,然后創(chuàng)建該實(shí)現(xiàn)類的實(shí)例(從java8開始可以直接使用Lambda表達(dá)式創(chuàng)建Callable對(duì)象)。
2】使用FutureTask類來包裝Callable對(duì)象,該FutureTask對(duì)象封裝了Callable對(duì)象的call()方法的返回值
3】使用FutureTask對(duì)象作為Thread對(duì)象的target創(chuàng)建并啟動(dòng)線程(因?yàn)镕utureTask實(shí)現(xiàn)了Runnable接口)
4】調(diào)用FutureTask對(duì)象的get()方法來獲得子線程執(zhí)行結(jié)束后的返回值
代碼實(shí)例:
public class Main { public static void main(String[] args){ MyThread3 th=new MyThread3(); //使用Lambda表達(dá)式創(chuàng)建Callable對(duì)象 //使用FutureTask類來包裝Callable對(duì)象 FutureTask<Integer> future=new FutureTask<Integer>( (Callable<Integer>)()->{ return 5; } ); new Thread(task,"有返回值的線程").start();//實(shí)質(zhì)上還是以Callable對(duì)象來創(chuàng)建并啟動(dòng)線程 try{ System.out.println("子線程的返回值:"+future.get());//get()方法會(huì)阻塞,直到子線程執(zhí)行結(jié)束才返回 }catch(Exception e){ ex.printStackTrace(); } } }
--------------------------------------三種創(chuàng)建線程方法對(duì)比--------------------------------------
實(shí)現(xiàn)Runnable和實(shí)現(xiàn)Callable接口的方式基本相同,不過是后者執(zhí)行call()方法有返回值,后者線程執(zhí)行體run()方法無返回值,因此可以把這兩種方式歸為一種這種方式與繼承Thread類的方法之間的差別如下:
1、線程只是實(shí)現(xiàn)Runnable或?qū)崿F(xiàn)Callable接口,還可以繼承其他類。
2、這種方式下,多個(gè)線程可以共享一個(gè)target對(duì)象,非常適合多線程處理同一份資源的情形。
3、但是編程稍微復(fù)雜,如果需要訪問當(dāng)前線程,必須調(diào)用Thread.currentThread()方法。
4、繼承Thread類的線程類不能再繼承其他父類(Java單繼承決定)。
注:一般推薦采用實(shí)現(xiàn)接口的方式來創(chuàng)建多線程
以上是“java中創(chuàng)建線程的方法有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。