Java多執行緒程式設計的方法總結(附範例)
這篇文章帶給大家的內容是關於Java多執行緒的實作方法總結(附範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
1.何時使用多執行緒程式設計
一個任務在正常情況下是依序執行的,但是如果目前任務裡有多個相似進程區塊(例如for,while語句) ,我們就可以考慮把這些程式碼區塊抽出來並行運行,無需阻塞
2.實作多執行緒的幾種方式
一種是繼承Thread類別重寫run方法,另一種是實作Runnable介面重寫run方法
啟動多執行緒很多情況下是為了處理並發進程,此時對於部分即時性要求不是那麼高的業務需求,我們還可以透過實作佇列的方式,異步實現。
3.範例
繼承Thread
/** * * @ClassName: ThreadByEx * @Description: TODO * @author Mr.jqCheng * @date 2018年9月26日 * */public class ThreadByEx extends Thread{ @Override public void run() { // TODO Auto-generated method stub System.out.println("我是继承线程"); } }
實作Runnable
/** * * @ClassName: ThreadByRunnable * @Description: TODO * @author Mr.jqCheng * @date 2018年9月26日 * */public class ThreadByRunnable implements Runnable{ /*public ThreadByRunnable() { this.run(); // TODO Auto-generated constructor stub }*/ public void run() { // TODO Auto-generated method stub System.out.println("我是实现进程"); } }
測試:
/** * * @ClassName: Test * @Description: TODO * @author Mr.jqCheng * @date 2018年9月26日 * */public class Test { public static void main(String[] args) { // 继承Thread启动的方法 ThreadByEx t1 = new ThreadByEx(); t1.start();// 启动线程 // 实现Runnable启动线程的方法 ThreadByRunnable r = new ThreadByRunnable(); Thread t2 = new Thread(r); t2.start();// 启动线程 //new ThreadByRunnable(); } }
執行結果:
我是繼承線程
我是實作進程
ok,簡單的多執行緒實作方式完成了,在呼叫start()的時候,該行程已經進入可執行狀態,等待系統執行。
執行緒處理的幾個常用方法:
void interrupt():向執行緒發送中斷請求,執行緒的中斷狀態將會被設定為true,如果目前執行緒被一個sleep呼叫阻塞,那麼將會拋出interrupedException異常。
static boolean interrupted():測試目前執行緒(目前正在執行指令的這個執行緒)是否被中斷。注意這是個靜態方法,呼叫這個方法會產生一個副作用就是它會將目前執行緒的中斷狀態重設為false。
boolean isInterrupted():判斷執行緒是否被中斷,這個方法的呼叫不會產生副作用即不改變執行緒的目前中斷狀態。
static Thread currentThread() : 傳回代表目前執行緒的Thread物件。
守護程式
用來服務不是服務程序的其他所有目前程序下的所有執行緒
實作deamon.setDaemon(true)就行,要在執行緒開啟之前啟用
範例
package com.orange.util; /** * * @ClassName: Test * @Description: TODO * @author Mr.jqCheng * @date 2018年9月26日 * */ public class Test { public static void main(String[] args) { Thread deamon2 = new Thread(new DaemonRunner2(), "otherRunner"); deamon2.start();// 启动线程 try { Thread.sleep(1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } Thread deamon = new Thread(new DaemonRunner(), "DaemonRunner"); // 设置为守护线程 deamon.setDaemon(true); deamon.start();// 启动线程 } static class DaemonRunner implements Runnable { public void run() { // TODO Auto-generated method stub try { Thread.sleep(300); Thread t = Thread.currentThread(); System.out.println(t); } catch (Exception e) { e.printStackTrace(); } finally { System.out.println("进入守护线程,说明现在还有其他线程在执行"); } } } static class DaemonRunner2 implements Runnable { public void run() { // TODO Auto-generated method stub try { Thread.sleep(1500); System.out.println("我是其他线程"); } catch (Exception e) { e.printStackTrace(); } } } }
執行結果:
Thread[DaemonRunner,5,main]
進入守護線程,說明現在還有其他執行緒在執行
我是其他線程
首先,先啟動其他線程,需要耗時1500ms,同時,主線程耗時1000ms後,開始進入守護線程,此時其它線程還在運行,到了守護線程,耗時300ms,其他線程仍在執行,繼續往下,守護線程執行完畢
但是如果我把守護線程的300ms改成500ms,會發生什麼事呢?
出現過兩種情況,畢竟在臨界值
1.我是其他線程
2.Thread[DaemonRunner,5,main]
進入守護線程,說明現在還有其他執行緒在執行
我是其他執行緒
以上是Java多執行緒程式設計的方法總結(附範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Java開發中,文件讀取是一個非常常見且重要的操作。隨著業務的成長,文件的大小和數量也不斷增加。為了提高檔案讀取的速度,我們可以採用多執行緒的方式來並行讀取檔案。本文將介紹如何在Java開發中最佳化檔案讀取多執行緒加速效能。首先,在進行檔案讀取前,我們需要先確定檔案的大小和數量。根據檔案的大小和數量,我們可以合理地設定線程的數量。過多的執行緒數量可能會導致資源浪費,

Java中volatile關鍵字的作用及應用場景詳解一、volatile關鍵字的作用在Java中,volatile關鍵字用來識別一個變數在多個執行緒之間可見,即保證可見性。具體來說,當一個變數被宣告為volatile時,任何對該變數的修改都會立即被其他執行緒所知曉。二、volatile關鍵字的應用程式場景狀態標誌volatile關鍵字適用於一些狀態標誌的場景,例如一

探索Java多執行緒的工作原理和特點引言:在現代電腦系統中,多執行緒已成為一種常見的並發處理方式。 Java作為一門強大的程式語言,提供了豐富的多執行緒機制,讓程式設計師可以更好地利用電腦的多核心處理器、提高程式運作效率。本文將探索Java多執行緒的工作原理和特點,並透過具體的程式碼範例來說明。一、多線程的基本概念多線程是指在一個程式中同時執行多個線程,每個線程處理不同

多執行緒環境下異常處理的要點:捕捉異常:每個執行緒使用try-catch區塊捕捉異常。處理異常:在catch區塊中列印錯誤訊息或執行錯誤處理邏輯。終止執行緒:無法復原時,呼叫Thread.stop()終止執行緒。 UncaughtExceptionHandler:處理未捕獲異常,需要實作該介面並指定給執行緒。實戰案例:線程池中的異常處理,使用UncaughtExceptionHandler來處理未捕獲異常。

Java並發鎖機制可確保多執行緒環境下,共享資源僅由一個執行緒存取。其類型包括悲觀鎖(獲取鎖再存取)和樂觀鎖(訪問後檢查衝突)。 Java提供了ReentrantLock(互斥鎖)、Semaphore(信號量)和ReadWriteLock(讀寫鎖)等內建並發鎖類別。使用這些鎖可以確保共享資源的執行緒安全訪問,如確保多個執行緒同時訪問共享變數counter時僅有一個執行緒更新其值。

Java多執行緒效能最佳化指南提供了五個關鍵最佳化點:減少執行緒建立和銷毀開銷避免不當的鎖爭用使用非阻塞資料結構利用Happens-Before關係考慮無鎖並行演算法

Java是一種廣泛應用於現代軟體開發的程式語言,其多執行緒程式設計能力也是其最大的優點之一。然而,由於多執行緒帶來的並發存取問題,Java中常常會出現多執行緒安全性問題。其中,java.lang.ThreadDeath就是一個典型的多執行緒安全問題。本文將介紹java.lang.ThreadDeath的原因以及解決方法。一、java.lang.ThreadDeath的原因

多執行緒偵錯技術解答:1.多執行緒程式碼除錯的挑戰:執行緒之間的互動導致複雜且難以追蹤的行為。 2.Java多執行緒偵錯技術:逐行調試執行緒轉儲(jstack)監視器進入和退出事件執行緒本地變數3.實戰案例:使用執行緒轉儲發現死鎖,使用監視器事件確定死鎖原因。 4.結論:Java提供的多執行緒偵錯技術可以有效解決與執行緒安全、死鎖和爭用相關的問題。
