亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java線程中斷及線程中斷的幾種使用場景小結

 更新時間:2024年01月17日 09:21:40   作者:David愛編程  
在并發(fā)編程中,合理使用線程中斷機制可以提高程序的魯棒性和可維護性,本文主要介紹了Java線程中斷及線程中斷的幾種使用場景小結,具有一定的參考價值,感興趣的可以了解一下

引言

在多線程編程中,線程中斷技術是確保程序健壯性和可靠性的不可或缺的一部分。本文將深入探討Java中的線程中斷技術,以通俗易懂的方式介紹其概念、機制以及在實際項目中的應用。

1. 線程中斷概述

在多線程編程中,線程是程序中的執(zhí)行單元,而線程中斷是一種機制,允許一個線程打斷另一個線程的正常執(zhí)行流程。這種機制為多線程環(huán)境下的協(xié)同工作提供了一種靈活而有效的方式。

線程中斷并不是強制性的,而是一種協(xié)作機制。通過線程中斷,我們可以向目標線程發(fā)出信號,通知它發(fā)生了一些特定的事件,而目標線程可以選擇如何應對這個事件。這種靈活性使得線程中斷成為并發(fā)編程中的一個重要工具。

以下是與線程中斷相關的幾個核心方法:

  • interrupt()方法:
    作用: 用于中斷目標線程,將目標線程的中斷標志位置為true。

    調用方式: Thread.currentThread().interrupt() 或 myThread.interrupt()。

  • isInterrupted()方法:
    作用: 返回調用線程的中斷狀態(tài),不會清除中斷標志。

    調用方式: Thread.currentThread().isInterrupted() 或 myThread.isInterrupted()。

  • interrupted()方法:
    作用: 返回調用線程的中斷狀態(tài),并清除中斷標志(靜態(tài)方法)。

    調用方式: Thread.interrupted()。

**注意:**這里的myThread代表的是你創(chuàng)建的線程實例的名字

2. Java中的線程中斷機制

在Java中,線程中斷是通過Thread類提供的interrupt()方法來實現(xiàn)的。調用interrupt()方法并不會直接中斷線程,而是將線程的中斷標志位置為true,表示線程已經被中斷。目標線程可以通過檢查自身的中斷狀態(tài)來確定是否被中斷,從而采取相應的行動。

這種設計使得線程中斷變得相對安全,因為線程仍然有機會在合適的時候完成它的工作,而不是被強制中止。同時,它也為程序員提供了更細粒度的控制,可以在適當?shù)臅r候中斷線程,從而提高程序的魯棒性。
例子:

public class InterruptExample {
    public static void main(String[] args) {
        Thread myThread = new Thread(() -> {
            while (!Thread.interrupted()) {
                // 線程執(zhí)行的操作
                System.out.println("Working...");
            }
            System.out.println("Thread is interrupted!");
        });

        myThread.start();

        // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
        try {
            Thread.sleep(2000);
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

3. 捕獲中斷信號

在實際應用中,我們需要了解目標線程是否被中斷。為此,Java提供了兩種方法:isInterrupted()和Thread.interrupted()。這兩者的區(qū)別在于前者不會改變中斷狀態(tài),而后者會清除中斷狀態(tài)。

is

interrupt

Thread.interrupted()示例:

// 示例代碼
public class InterruptCaptureExample {
    public static void main(String[] args) {
        Thread myThread = new Thread(() -> {
            while (!Thread.interrupted()) {
                // 線程執(zhí)行的操作
                System.out.println("Working...");
            }
            // 線程中斷狀態(tài)被Thread.interrupted()清除了
            System.out.println("Thread is interrupted: " + Thread.interrupted());
        });

        myThread.start();

        // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
        try {
            Thread.sleep(2000);
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

isInterrupted方法示例:

public class InterruptCaptureExample {
    public static void main(String[] args) {
        Thread myThread = new Thread(() -> {
            try {
                while (!Thread.interrupted()) {
                    // 模擬線程執(zhí)行的操作
                    System.out.println("Working...");
                    Thread.sleep(500); // 模擬耗時操作
                }
            } catch (InterruptedException e) {
                System.out.println("Thread is interrupted during work!");
                // 重新設置中斷狀態(tài),因為Thread.interrupted清除了線程中斷狀態(tài)
              // 否則myThread.isInterrupted()為false
              Thread.currentThread().interrupt(); 
            } finally {
                // 清理工作,確保資源釋放
                System.out.println("Cleaning up resources...");
            }
        });

        myThread.start();

        // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
        try {
            Thread.sleep(2000);
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        // 判斷線程是否被中斷
        boolean isInterrupted = myThread.isInterrupted();
        System.out.println("Thread is interrupted: " + isInterrupted);
    }
}

4. 處理中斷

線程被中斷時,應該采取哪些操作?本節(jié)提供一些建議,涉及到線程在中斷時的清理工作和資源釋放,確保線程的優(yōu)雅退出。

例子:

public class CleanupOnInterrupt {
    public static void main(String[] args) {
        Thread myThread = new Thread(() -> {
            try {
                while (!Thread.interrupted()) {
                    // 線程執(zhí)行的操作
                    System.out.println("Thread is working...");
                    Thread.sleep(1000); // 模擬線程執(zhí)行任務
                }
            } catch (InterruptedException e) {
                System.out.println("Thread is interrupted during work!");
            } finally {
                // 清理工作,確保資源釋放
                System.out.println("Cleaning up resources...");
            }
        });

        myThread.start();
        try {
            // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
            Thread.sleep(5000); // 模擬主線程等待一段時間后中斷子線程
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

5. 等待中的線程中斷

本章探討處在等待狀態(tài)中的線程如何響應中斷。通過實例演示wait()和sleep()方法,以及如何使用InterruptedException來處理中斷,使讀者朋友能夠理解這一關鍵概念。

例子:

public class ThreadWaitInterrupt {
    public static void main(String[] args) {
        Object lock = new Object();

        Thread myThread = new Thread(() -> {
            synchronized (lock) {
                try {
                    lock.wait();
                } catch (InterruptedException e) {
                    System.out.println("Thread is interrupted!");
                }
            }
        });

        myThread.start();
        try {
            // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
            Thread.sleep(3000); // 模擬主線程等待一段時間后中斷子線程
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

6. 優(yōu)雅的線程中斷

通過一個生動的實例,演示如何在實際應用中使用線程中斷。以文件下載為例,展示如何通過中斷機制提高程序的響應性和用戶體驗。

例子:

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;

class FileDownloadThread extends Thread {
    private final String fileUrl;
    private final String destinationFile;

    public FileDownloadThread(String fileUrl, String destinationFile) {
        this.fileUrl = fileUrl;
        this.destinationFile = destinationFile;
    }

    @Override
    public void run() {
        try (InputStream in = new URL(fileUrl).openStream();
             FileOutputStream fileOutputStream = new FileOutputStream(destinationFile)) {

            byte[] buffer = new byte[1024];
            int bytesRead;
            while ( (bytesRead = in.read(buffer)) != -1) {
                if (isInterrupted()){
                    System.out.println("File download cancel!");
                    break;
                }else{
                    fileOutputStream.write(buffer, 0, bytesRead);
                }
                System.out.println("File download completed!");
            }

        } catch (IOException e) {
            System.out.println("File download failed: " + e.getMessage());
        }
    }
}

public class DownLoad {
    public static void main(String[] args) {
        String fileUrl = "https://download.oracle.com/java/21/latest/jdk-21_linux-aarch64_bin.tar.gz";
        String destinationFile = "downloadedFile.zip";

        FileDownloadThread downloadThread = new FileDownloadThread(fileUrl, destinationFile);
        downloadThread.start();

        // 模擬用戶點擊取消下載操作
        try {
            Thread.sleep(1000); // 用戶等待了1秒后取消下載
            downloadThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

在這個例子中,F(xiàn)ileDownloadThread負責下載文件,通過檢查線程的中斷狀態(tài)來判斷是否繼續(xù)下載。主線程模擬用戶點擊取消下載操作,調用downloadThread.interrupt()來中斷文件下載線程。線程在被中斷后,會立即停止下載并輸出相應的信息,使用戶體驗更加友好。這展示了線程中斷在提高程序響應性方面的實際應用。

7. 避免死鎖

死鎖是多線程編程中常見的問題,而線程中斷可以用來避免死鎖。通過在獲取資源時檢查線程中斷狀態(tài),可以及時中止可能導致死鎖的線程。

  • 技術點:

    • 使用線程中斷來打破死鎖。
    • 如何檢查線程中斷狀態(tài)以避免死鎖。
  • 實現(xiàn):

    • 在多線程應用中,當一個線程等待獲取多個鎖時,可能發(fā)生死鎖。通過在獲取每個鎖的過程中檢查線程中斷狀態(tài),可以避免死鎖的發(fā)生。當線程被中斷時,它可以選擇立即釋放已經獲取的鎖,防止死鎖的發(fā)生。
public class DeadlockAvoidanceExample {
    private final Object lock1 = new Object();
    private final Object lock2 = new Object();

    public void executeThread1() {
        synchronized (lock1) {
            System.out.println("Thread 1: Holding lock 1");
            try {
                Thread.sleep(3000);
            } catch (InterruptedException e) {
                System.out.println("Thread 1: interrupt");
                return;
            }
            System.out.println("Thread 1: Waiting for lock 2");
            synchronized (lock2) {
                System.out.println("Thread 1: Holding lock 1 and lock 2");
            }
        }
    }

    public void executeThread2() {
        synchronized (lock2) {
            System.out.println("Thread 2: Holding lock 2");
            try {
                Thread.sleep(10000);
            } catch (InterruptedException e) {
                System.out.println("Thread 2: interrupt");
                //Thread.currentThread().interrupt();
                return;
            }
            System.out.println("Thread 2: Waiting for lock 1");
            synchronized (lock1) {
                System.out.println("Thread 2: Holding lock 1 and lock 2");
            }
        }
    }

    public static void main(String[] args) throws InterruptedException {
        DeadlockAvoidanceExample deadlockAvoidanceExample =new DeadlockAvoidanceExample();
        Thread t1 = new Thread(){
           public void run(){
               deadlockAvoidanceExample.executeThread1();
               //deadlockAvoidanceExample.executeThread2();
            }
        };
        Thread t2 = new Thread(){
            public void run(){
                // deadlockAvoidanceExample.executeThread1();
                deadlockAvoidanceExample.executeThread2();
            }
        };
        t1.start();
        t2.start();
        // 主線程sleep 2秒
        Thread.sleep(2000);
        // 中斷t2線程,釋放鎖,t1線程可以獲得鎖繼續(xù)執(zhí)行
        t2.interrupt();

    }

執(zhí)行效果如下:

res

在這個例子中,DeadlockAvoidanceExample類展示了一個可能導致死鎖的情況。通過在獲取鎖的過程中檢查線程中斷狀態(tài),可以在發(fā)生死鎖時及時中止線程,從而避免死鎖的發(fā)生。

8. 最佳實踐和注意事項

總結線程中斷的最佳實踐,提醒讀者朋友注意可能的陷阱和常見誤區(qū)。包括如何避免濫用線程中斷,以及在不同場景下的最佳應用方式。

  • 技術點:

    • 不同場景下的線程中斷最佳實踐。
    • 避免濫用線程中斷的策略。
  • 實現(xiàn):

    • 在使用線程中斷時,確保目標線程能夠正確響應中斷信號,避免出現(xiàn)死循環(huán)或不響應中斷的情況。
    • 謹慎處理捕獲的InterruptedException,避免忽略異?;騼H僅輸出日志而不采取實際行動的情況。
  • 例子:

public class InterruptBestPracticesExample {
    public static void main(String[] args) {
        Thread myThread = new Thread(() -> {
            try {
                while (!Thread.interrupted()) {
                    // 線程執(zhí)行的操作
                    System.out.println("Thread is working...");
                    Thread.sleep(1000); // 模擬線程執(zhí)行任務
                }
            } catch (InterruptedException e) {
                System.out.println("Thread is interrupted during work!");
                Thread.currentThread().interrupt(); // 重新設置中斷狀態(tài)
            } finally {
                // 清理工作,確保資源釋放
                System.out.println("Cleaning up resources...");
            }
        });

        myThread.start();
        try {
            // 在適當?shù)臅r機調用 myThread.interrupt() 來中斷線程
            Thread.sleep(5000); // 模擬主線程等待一段時間后中斷子線程
            myThread.interrupt();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

9. 結論

通過本文的學習,我們深入剖析了Java線程中斷技術,理解了其核心概念和實際應用。在并發(fā)編程中,合理使用線程中斷機制可以提高程序的魯棒性和可維護性。

  • 概括:

    • 線程中斷是一種協(xié)作機制,通過它可以向目標線程發(fā)出信號,通知它發(fā)生了一些特定的事件。
    • 在Java中,線程中斷是通過Thread類提供的interrupt()方法來實現(xiàn)的,通過檢查自身的中斷狀態(tài)來確定是否被中斷。
    • 我們通過實例演示了線程中斷的各種應用,包括優(yōu)雅的線程中斷、避免死鎖等場景。
    • 在實際應用中,合理使用線程中斷可以提高程序的響應性和用戶體驗,但也需要注意避免濫用和正確處理中斷異常。

到此這篇關于Java線程中斷及線程中斷的幾種使用場景小結的文章就介紹到這了,更多相關Java線程中斷內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 如何更優(yōu)雅地獲取spring boot yml中的值

    如何更優(yōu)雅地獲取spring boot yml中的值

    這篇文章主要給大家介紹了關于如何更優(yōu)雅地獲取spring boot yml中值的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用spring boot具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • Flink作業(yè)Task運行源碼解析

    Flink作業(yè)Task運行源碼解析

    這篇文章主要為大家介紹了Flink作業(yè)Task運行源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • 詳解Struts2攔截器機制

    詳解Struts2攔截器機制

    這篇文章主要介紹了詳解Struts2攔截器機制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Springboot項目長時間不進行接口操作,提示HikariPool-1警告的解決

    Springboot項目長時間不進行接口操作,提示HikariPool-1警告的解決

    這篇文章主要介紹了Springboot項目長時間不進行接口操作,提示HikariPool-1警告的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 淺談JVM中的JOL

    淺談JVM中的JOL

    我們天天都在使用java來new對象,但估計很少有人知道new出來的對象到底長的什么樣子?對于普通的java程序員來說,可能從來沒有考慮過java中對象的問題,不懂這些也可以寫好代碼。今天,給大家介紹一款工具JOL,可以滿足大家對java對象的所有想象。
    2021-06-06
  • 詳解spring中使用solr的代碼實現(xiàn)

    詳解spring中使用solr的代碼實現(xiàn)

    本篇文章主要介紹了詳解spring中使用solr的代碼實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • SpringBoot整合Shiro和Redis的示例代碼

    SpringBoot整合Shiro和Redis的示例代碼

    這篇文章主要介紹了SpringBoot整合Shiro和Redis的示例代碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • SpringCloud Gateway實現(xiàn)限流功能詳解

    SpringCloud Gateway實現(xiàn)限流功能詳解

    SpringCloud Gateway 是 Spring Cloud 的一個全新項目,它旨在為微服務架構提供一種簡單有效的統(tǒng)一的 API 路由管理方式。這篇文章主要介紹了SpringCloud Gateway實現(xiàn)限流,需要的朋友可以參考下
    2022-11-11
  • mybatis分割字符串并循環(huán),實現(xiàn)in多個參數(shù)的操作

    mybatis分割字符串并循環(huán),實現(xiàn)in多個參數(shù)的操作

    這篇文章主要介紹了mybatis分割字符串并循環(huán),實現(xiàn)in多個參數(shù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringCloud Feign高級配置詳解

    SpringCloud Feign高級配置詳解

    這篇文章主要介紹了SpringCloud Feign高級配置,feign是netflix提供的服務間基于http的rpc調用框架,在spring cloud得到廣泛應用
    2022-09-09

最新評論