這篇文章將為大家詳細講解有關如何從Thread和Runnable接口以及Callable方面來創建線程,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
十多年的崗巴網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。網絡營銷推廣的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整崗巴建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。創新互聯從事“崗巴網站設計”,“崗巴網站推廣”以來,每個客戶項目都認真落實執行。
我是線程,我的英文名叫 Thread,別看我現在風光無限,好像人盡皆知的樣子,然而我的身世卻悲慘離奇。
接下來我要把我的出生過程演示給你看,這也是我的第一段人生經歷。
線程最原始的創建方式,只需要繼承 Thread 類,重寫 run() 方法即可,實現代碼如下:
// 創建方式 1:繼承 Thread class MyThread extends Thread { @Override public void run() { System.out.println("你好,線程~"); } } // 測試 public class ThreadExample { public static void main(String[] args) { // 創建線程 Thread thread = new MyThread(); // 啟動線程 thread.start(); } }
以上創建線程的方式略顯繁瑣,我們也可以使用匿名對象的方式,在創建 Thread 類的時候就直接重寫 run() 方法,實現代碼如下:
// 變種 1:匿名方式創建線程 Thread t1 = new Thread() { @Override public void run() { System.out.println("線程變種"); } }; // 啟動線程 t1.start();
Java 語言的設計是單繼承,所以當繼承了 Thread 之后,就不能再繼承其他類了。
也就是說,如果我一直呆在親生母親(extends Thread)的身邊,那么就得不到好的教育,所以長大之后也注定會普普通通,這可能就是母親把我過繼給遠房親戚的原因吧。
在 Java 語言中,雖然不能實現多繼承,但可以實現多接口,所以我在第二位母親家,過得也算如魚得水。
和繼承 Thread 類差不多,實現 Runnable 接口也是重寫 run() 方法,具體實現代碼如下:
public class ThreadExample2 { // 創建方式 2:實現 Runnable 接口 static class MyThread implements Runnable { @Override public void run() { System.out.println("你好,線程~"); } } // 代碼測試 public static void main(String[] args) { // 創建 Runnable 子類 MyThread myThread = new MyThread(); // 創建線程 Thread thread = new Thread(myThread); // 啟動線程 thread.start(); } }
以上實現 Runnable 的接口有更簡單的實現方法,我們可以使用匿名 Runnable 來創建一個線程,如下代碼所示:
// 變種 1:匿名 Runnable 方式 Thread t2 = new Thread(new Runnable() { @Override public void run() { System.out.println("我是線程變種方法~"); } }); // 啟動線程 t2.start();
在 JDK 8 之后,我們可以使用 Lambda 表達式來操作代碼了,所以對于創建匿名 Runnable 類,我們也有了更簡單的實現方法,如下代碼所示:
// 變種 2:使用 Lambda 匿名 Runnable 方式 Thread t3 = new Thread(() -> { System.out.println("我是變種 2~"); }); // 啟動線程 t3.start();
注意:以上實現代碼只支持 JDK 1.8+ 版本。
雖然我的前兩位母親對我都很好,但對于我這樣一個氣宇軒揚、骨骼驚奇將來要拯救宇宙和維護世界和平的少年來說,只在國內混未免局限性太大,所以我一直想去大洋彼岸追尋自己的夢想,然而以「前兩位」母親的財力不足以支撐我這樣做。
然而我的第二個家庭和村里的首富一家是至交,得知我的志向之后,他們一家愿意傾囊相授,舉一家之力幫我去大洋彼岸追尋我的夢想。于是在感激之余,我的第二位母親讓我當場認下首富一家為我的干爹、干媽。就這樣,我就有了第三位母親了。
前兩種創建方式雖然不錯,但都不能接收線程執行之后的返回值,于是在 JDK 1.5 之后就加入了 Callable 和 Futrue,用于接收線程執行之后的返回值,具體的實現代碼如下:
import java.util.Random; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; /** * 線程創建示例 3 */ public class CreateThreadExample3 { // 創建方式 3:實現 Callable 接口 static class MyCallable implements Callable<Integer> { @Override public Integer call() throws Exception { int num = new Random().nextInt(10); System.out.println("生成隨機數:" + num); return num; } } // 代碼測試 public static void main(String[] args) throws ExecutionException, InterruptedException { // 創建 Callable 子對象 MyCallable callable = new MyCallable(); // 使用 FutureTask 配合 Callable 子對象得到執行結果 FutureTask<Integer> futureTask = new FutureTask<>(callable); // 創建線程 Thread thread = new Thread(futureTask); // 啟動線程 thread.start(); // 得到線程執行的結果 int result = futureTask.get(); System.out.println("主線程中拿到子線程執行結果:" + result); } }
以上代碼的執行結果如下:
從以上結果可以看出,使用 Callable 配合 FutrueTask 可以正確拿到線程執行之后的返回值。而我的故事也在這里結束了,我最終不負三位母親所望,雖不能拯救宇宙和維護世界和平,但卻也能在程序界作出自己的一些貢獻,這就是我和我三位母親的故事。
第一人稱“我”(Thread)的視角講了線程創建的三種方式,第一種是繼承 Thread,但因為 Java 語言不允許多繼承,所以當繼承了 Thread 之后就不能繼承其他類了,于是就有了第二種方式實現 Runnable 接口的方式。然而前兩種實現雖然可以創建線程,但不能接收線程執行之后的返回值,于是就有了第三種實現 Callable,通過它我們可以取得線程執行之后的返回值。
關于如何從Thread和Runnable接口以及Callable方面來創建線程就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
新聞標題:如何從Thread和Runnable接口以及Callable方面來創建線程
標題網址:http://vcdvsql.cn/article4/podsie.html
成都網站建設公司_創新互聯,為您提供面包屑導航、做網站、網站制作、網站策劃、網站排名、定制網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯