sunny123456

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  1796 随笔 :: 22 文章 :: 24 评论 :: 226万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

线程中断方法Thread.currentThread().interrupt()、Thread.interrupted()、Thread.currentThread().isInterrupted()

本文介绍3个线程中断方法的意义及使用结果。在ReentrantLock类中会看到有使用的地方。

  1. Thread.currentThread().interrupt():表示为当前线程打中断标记。
  2. Thread.interrupted():表示清除中断标记,如果当前线程中断,返回true,否则返回false
  3. Thread.currentThread().isInterrupted():表示查看当前线程的状态是否中断,不清除中断标记

测试代码

public static void main(String[] args) {
        System.out.println("线程开始状态1"+Thread.currentThread().isInterrupted());
        // 为线程打中断标记
        Thread.currentThread().interrupt();
        // 当前线程状态是否中断,上一行打中断标记后就是true
        System.out.println("线程打中断标记状态2"+Thread.currentThread().isInterrupted());
        //获取线程中断状态true,并清除
        boolean interrupted = Thread.interrupted();
        System.out.println("中断标记"+interrupted);
        // 清除完中断标记,中断状态false
        System.out.println("线程清除中断标记后状态3"+Thread.currentThread().isInterrupted());
        // 线程阻塞;线程中断过,这里就不会阻塞,继续往下执行
        LockSupport.park();
        boolean interrupted2 = Thread.interrupted();
        System.out.println("继续运行"+interrupted2);
 
    }

结果输出图:

 这里注意:

LockSupport.park();

如果在此之前标记过中断,这里不会阻塞,会继续执行。

情况2:

注释第2行代码,再看运行情况

应用场景

// java.util.concurrent.locks.AbstractQueuedSynchronizer#acquireQueued
 
final boolean acquireQueued(final Node node, int arg) {
        boolean failed = true;
        try {
            boolean interrupted = false;
            for (;;) {
                final Node p = node.predecessor();
                if (p == head && tryAcquire(arg)) {
                    setHead(node);
                    p.next = null; // help GC
                    failed = false;
                    return interrupted;
                }
                if (shouldParkAfterFailedAcquire(p, node) &&
                    parkAndCheckInterrupt())
                    interrupted = true;
            }
        } finally {
            if (failed)
                cancelAcquire(node);
        }
    }
 
static void selfInterrupt() {
        Thread.currentThread().interrupt();
    }
 
 
 
private final boolean parkAndCheckInterrupt() {
// 阻塞住,等待被唤醒
        LockSupport.park(this);
//清除中断标记,下次线程还会被阻塞,这里返回false
        return Thread.interrupted();
    }

 

原文链接:https://blog.csdn.net/wangfenglei123456/article/details/122706002
posted on   sunny123456  阅读(749)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示