JAVA多線程的幾種實現方式

?1. 繼承?Thread?類?
  • ?原理?:通過繼承?Thread?類并重寫?run()?方法定義線程任務,調用?start()?啟動線程?。
  • ?代碼示例?:
    public class MyThread extends Thread {@Overridepublic void run() {System.out.println("線程 " + getName() + " 執行");for (int i = 0; i < 5; i++) {System.out.println(getName() + ":" + i);}}public static void main(String[] args) {MyThread t1 = new MyThread();MyThread t2 = new MyThread();t1.start();t2.start();}
    }
    
    ?缺點?:單繼承限制,無法繼承其他類?。

?2. 實現?Runnable?接口?
  • ?原理?:將線程任務解耦,通過?Runnable?對象傳遞給?Thread?構造函數?。
  • ?代碼示例?:
    public class RunnableDemo implements Runnable {@Overridepublic void run() {for (int i = 0; i < 5; i++) {System.out.println(Thread.currentThread().getName() + ":" + i);}}public static void main(String[] args) {Runnable task = new RunnableDemo();Thread t1 = new Thread(task, "Thread-1");Thread t2 = new Thread(task, "Thread-2");t1.start();t2.start();}
    }
    
    ?優勢?:支持多接口實現,適合資源共享場景?。

?3. 使用?Callable?和?Future?
  • ?原理?:通過?Callable?接口定義可返回結果的任務,配合?FutureTask?獲取異步計算結果?。
  • ?代碼示例?:
    import java.util.concurrent.*;public class CallableDemo implements Callable<Integer> {@Overridepublic Integer call() throws Exception {int sum = 0;for (int i = 0; i < 5; i++) {sum += i;}return sum;}public static void main(String[] args) throws ExecutionException, InterruptedException {ExecutorService executor = Executors.newSingleThreadExecutor();Future<Integer> future = executor.submit(new CallableDemo());System.out.println("計算結果:" + future.get());executor.shutdown();}
    }
    
    ?特點?:支持返回值,可處理異常?。

?4. 線程池(ExecutorService?
  • ?原理?:通過線程池管理線程生命周期,減少資源開銷?。
  • ?代碼示例?:
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;public class ThreadPoolDemo {public static void main(String[] args) {ExecutorService pool = Executors.newFixedThreadPool(2);for (int i = 0; i < 5; i++) {pool.submit(() -> {System.out.println(Thread.currentThread().getName() + " 執行任務");});}pool.shutdown();}
    }
    
    ?優勢?:提高線程復用率,控制并發數量?。

?總結?
?實現方式??適用場景?
繼承?Thread簡單任務,無需資源共享
實現?Runnable多接口、資源共享
Callable/Future需要返回結果或處理異常
線程池高并發、資源復用

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/79201.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/79201.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/79201.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

爬蟲(基本知識介紹,urllib庫的說明)

爬蟲 爬蟲基礎&#xff08;一些基本原理的梳理&#xff09; scheme://[username:password]hostname[:port][/path][;parameters][?query][#fragment] 注&#xff1a; parameters 和 query 混用&#xff0c;并且現在 query 用的多 ?query 查詢 &#xff0c;用來查詢某類資源…

探秘串口服務器廠家:背后的故事與應用

在科技飛速發展的今天&#xff0c;串口服務器作為連接串口設備與網絡的橋梁&#xff0c;在工業自動化、智能交通、智能家居等眾多領域發揮著關鍵作用。你是否好奇&#xff0c;那些生產串口服務器的廠家究竟有著怎樣的故事&#xff1f;它們的產品背后又蘊含著怎樣的原理呢&#…

工廠能耗系統智能化解決方案 —— 安科瑞企業能源管控平臺

安科瑞顧強 政策背景與“雙碳”戰略驅動 2025年《政府工作報告》明確提出“單位國內生產總值能耗降低3%左右”的目標&#xff0c;要求通過產業結構升級&#xff08;如高耗能行業技術革新或轉型&#xff09;、能源結構優化&#xff08;提高非化石能源占比&#xff09;及數字化…

BI面向模型開發和面向報表開發,有什么區別?

在數字化時代&#xff0c;商業智能&#xff08;BI&#xff09;已成為企業決策不可或缺的工具。BI項目實施時&#xff0c;通常有兩種開發模式&#xff1a;面向模型開發和面向報表開發。雖然兩者都旨在通過數據驅動決策&#xff0c;但在開發邏輯、目標價值和技術路徑上存在顯著差…

OpenHarmony人才認證證書

OpenHarmony人才認證體系目前支持初級工程師認證&#xff0c;要求了解OpenHarmony開源項目、生態進展及系統移植等基礎知識&#xff0c;熟練掌握OpenHarmony的ArkUI、分布式軟總線、分布式硬件、分布式數據管理等基礎能力使用&#xff0c;具備基礎的開發能力。 考試流程可參考O…

映射網絡路路徑和ftp路徑原理是什么,如何使用,有什么區別

文章目錄 一、原理1. 映射網絡路徑2. FTP路徑 二、使用方法1. 映射網絡路徑2. FTP路徑 三、主要區別1. 協議與功能2. 安全性與權限3. 適用場景 四、如何選擇&#xff1f;五、注意事項 映射網絡路徑&#xff08;如SMB/CIFS或NFS&#xff09;和FTP路徑&#xff08;FTP/FTPS/SFTP&…

Windows 圖形顯示驅動開發-WDDM 1.2功能—Windows 8 中的 DirectX 功能改進(一)

Windows 8包括 Microsoft DirectX 功能改進&#xff0c;使開發人員、最終用戶和系統制造商受益。 功能改進在以下幾個方面&#xff1a; 像素格式 (5551、565、4444) &#xff1a;在低功耗硬件配置下&#xff0c;DirectX 應用程序的性能更高。雙精度著色器功能&#xff1a;高級…

GitHub 趨勢日報 (2025年04月15日)

本日報由 TrendForge 系統生成 https://trendforge.devlive.org/ &#x1f4c8; 今日整體趨勢 Top 10 排名項目名稱項目描述今日獲星總星數語言1yeongpin/cursor-free-vip[Support 0.48.x]&#xff08;Reset Cursor AI MachineID & Auto Sign Up / In & Bypass Higher…

2025年推薦使用的開源大語言模型top20:核心特性、選擇指標和開源優勢

李升偉 編譯 隨著人工智能技術的持續發展&#xff0c;開源大型語言模型&#xff08;LLMs&#xff09;正變得愈發強大&#xff0c;使最先進的AI能力得以普及。到2025年&#xff0c;開源生態系統中涌現出多個關鍵模型&#xff0c;它們在各類應用場景中展現出獨特優勢。 大型語言…

回收鍍錫廢水的必要性(筆記)

鍍錫廢水若直接排放&#xff0c;將對環境、經濟和社會造成多重危害&#xff0c;其回收處理具有迫切性和深遠意義。以下從環境、資源、法規、技術與實踐、可持續發展五大維度展開分析&#xff1a; 一、環境危害的緊迫性&#xff1a;重金屬與污染物的致命威脅 成分復雜&#xf…

14.2 - VDMA彩條顯示實驗之動態時鐘

文章目錄 1 實驗任務2 系統框圖3 硬件設計4 軟件設計4.1 dynclk_api.h文件4.2 math_compat.h文件4.3 dynclk_api.c文件4.4 main.c文件 1 實驗任務 參見14.1。 2 系統框圖 參見14.1。 3 硬件設計 注意事項&#xff1a;基于14.1做如下改動 使能Clocking Wizard IP核的Dynam…

在邊緣端進行tensorflow模型的部署(小白初探)

1.配置tensorflow的環境 &#xff08;我是安裝GPU版本的&#xff09; 建議參考這個博主的文章&#xff0c;確實非常快速&#xff01; 十分鐘安裝Tensorflow-gpu2.6.0本機CUDA12 以及numpymatplotlib各包版本協調問題_tensorflow cuda12-CSDN博客 2.學習自制數據集 &#xf…

windows下使用nginx + waitress 部署django

架構介紹 linux一般采用nginx uwsgi部署django&#xff0c;在Windows下&#xff0c;可以取代uwsgi的選項包括Waitressa、Daphnea、Hypercoma和Gunicorna(通過WSLa 運行)。windows服務器一般采用nginx waitress 部署django&#xff0c;,他們的關系如下 django是WEB應用…

利用pnpm patch命令實現依賴包熱更新:精準打補丁指南

需求場景 在Element Plus的el-table組件二次開發中&#xff0c;需新增列顯示/隱藏控件功能。直接修改node_modules源碼存在兩大痛點&#xff1a; 團隊協作時修改無法同步 依賴更新導致自定義代碼丟失 解決方案選型 通過patch-package工具實現&#xff1a; &#x1f4e6; 非…

ThinkPad T520 無法讀到硬盤 問題排查思路

錯誤提示&#xff1a;2100:detection error on hdd0(Main hdd) 1、判斷錯誤提示含義 表示電腦在啟動時無法檢測到主硬盤&#xff08;HDD0&#xff09;。 2、 常見原因&#xff1a; 硬盤松動或接觸不良 → 特別是筆記本在移動或震動后&#xff0c;硬盤排線松了。 硬盤損壞 →…

Doris部署生產集群最低要求的部署方案

Doris生產集群最低部署方案&#xff08;2025年4月版&#xff09; 一、節點規劃與數量 1. FE節點&#xff08;Frontend&#xff09; 數量&#xff1a;至少 3個節點&#xff08;1個Follower 2個 Observer&#xff09;&#xff0c;確保高可用&#xff08;HA&#xff09;。角色分…

游戲引擎學習第227天

今天的計劃 今天的工作重點是進行吸引模式&#xff08;attract mode&#xff09;的開發&#xff0c;主要是處理游戲的進出和其他一些小的細節問題&#xff0c;這些是之前想要整理和清理的部分。我做了一些工作&#xff0c;將游戲代碼中的不同部分分離到邏輯上獨立的區域&#…

spark-SQL數據加載和保存

數據加載與保存 通用方式&#xff1a; 通過 spark.read.load 和 df.write.save 實現數據加載與保存。可利用 format 指定數據格式&#xff0c;如 csv 、 jdbc 等&#xff1b; option 用于設置特定參數&#xff0c;像 jdbc 格式下的數據庫連接信息&#xff1b; load 和 save 則…

算法升級戰報:亞馬遜受眾定向工具實測點擊成本降37%

隨著廣告成本居高不下&#xff0c;精準投放成為賣家們繞不開的焦慮點。而最近一輪亞馬遜DSP廣告系統的算法升級&#xff0c;似乎正在給這場投放內卷帶來新的轉機。在這篇文章中&#xff0c;我們將基于實際測試數據&#xff0c;詳細解析亞馬遜受眾定向工具的表現&#xff0c;并復…

大帶寬服務器的優勢

大帶寬服務器最大的優勢就在于可以顯著提高數據傳輸的速度&#xff0c;這對于有著高流量應用和實時數據交換需求的企業來說&#xff0c;大帶寬服務器中的帶寬越大&#xff0c;所提供的數據傳輸速度就越快&#xff0c;同時網絡的延遲度也會變低&#xff0c;所以大帶寬服務器往往…