interrupt()、interrupted()和isInterrupted()的区别与使用

文章详细介绍了Java中线程的interrupt()、interrupted()和isInterrupted()方法的区别。interrupt()设置中断标志但不立即停止线程;interrupted()检查并清除当前线程的中断状态;isInterrupted()仅检查中断状态而不清除。文中通过示例代码展示了这些方法的使用,并强调了中断线程需在run方法内响应中断标志。

在Java并发编程中,对于线程的Thread类中有这样三个方法:interrupt()方法、interrupted()方法和isInterrupted()方法。那么这三个方法的有啥区别呢?首先看一下对这三个方法的解释:

interrupt()方法:表示可以中断线程,实际上只是给线程设置一个中断标志,但是线程依旧会执行。
interrupted()方法:Thread类的静态方法。检查当前线程的中断标志,返回一个boolean并清除中断状态,其连续两次调用的返回结果不一样,因为第二次调用的时候线程的中断状态已经被清除,会返回一个false。
isInterrupted()方法:测试线程是否被中断,不会清除中断状态。
        下面对这三个方法进行演示和说明:

        首先定义一个线程类,然后在main方法中进行测试,代码如下:

class TestThread extends Thread{
    @Override
    public void run() {
        for (int i = 1; i <= 5; i++) {
            System.out.println(Thread.currentThread().getName() + "正在打印 i = " + i);
        }
    }
}
 
public class TestInterrupted {
    public static void main(String[] args) {
        TestThread  mt = new TestThread();
        mt.start();
        mt.interrupt();
        System.out.println("第一次调用isInterrupted()方法,值为:" + mt.isInterrupted());
        System.out.println("第二次调用isInterrupted()方法,值为:" + mt.isInterrupted());
        System.out.println("thread是否存活:" + mt.isAlive());
    }
}

执行结果如下:

         从结果中可以看出:在调用interrupt()方法之后,线程依旧在执行,并没有停止,因为interrupt()方法只是给线程设置了中断标志而已。其次,两次调用的isInterrupted()方法都输出了true,这也佐证了isInterrupted()方法并不会清除线程的中断状态。

        接下来对代码进行修改,添加interrupted()方法的调用:

public class TestInterrupted {
    public static void main(String[] args) {
        TestThread  mt = new TestThread();
        mt.start();
        mt.interrupt();
        System.out.println("第一次调用isInterrupted()方法,值为:" + mt.isInterrupted());
        System.out.println("第二次调用isInterrupted()方法,值为:" + mt.isInterrupted());
        System.out.println("调用interrupted()方法,值为:" + Thread.interrupted());
        System.out.println("调用interrupted()方法,值为:" +Thread.interrupted());
        System.out.println("thread是否存活:" + mt.isAlive());
    }
}

   执行结果如下:

       从执行结果来看,interrupted()方法的执行结果好像和我们预期的结果不一样。前面提到:interrupted()方法连续两次调用的返回结果不一样,因为第二次调用的时候线程的中断状态已经被清除,会返回一个false。按这个来说的话,这里的执行结果应该是一个true,一个false。

        这里有一个注意点:interrupted()方法测试的是当前线程是否被中断。但是这里的当前线程是main线程,而mt.interrupted()中断的是mt线程,而不是main线程。也就是说,当前线程main并没有被中断过,即Thread.interrupted()方法其实相当于main.interrupted(),而Thread.interrupted()方法检测的是mt线程有没有被中断。

        来看下面的代码:

public class TestInterrupted {
    public static void main(String[] args) {
        Thread.currentThread().interrupt();
        System.out.println("第一次调用isInterrupted()方法,值为:" + Thread.currentThread().isInterrupted());
        System.out.println("调用interrupted()方法,值为:" + Thread.currentThread().interrupted());
        System.out.println("调用interrupted()方法,值为:" +Thread.currentThread().interrupted());
    }
}

执行结果如下:

 上面都是针对当前线程进行操作,其运行结果也符合我们的预期:true-true-false,因为interrupted()方法是有检测中断并清除中断状态的作用。

        那么,如何才能中断mt线程呢?

         如果想要是通过调用interrupt()方法真正的终止线程,则可以在线程的run方法中做处理即可,比如直接跳出run()方法使线程结束,视具体情况而定,下面是一个例子。

class TestThread extends Thread{
    @Override
    public void run() {
        for (int i = 1; i <= 5; i++) {
            System.out.println(Thread.currentThread().getName() + "正在打印 i = " + i);
            if(this.isInterrupted()){//检查中断状态
                System.out.println("通过this.isInterrupted()检测到中断");
                System.out.println("第一个interrupted()"+this.interrupted());
                System.out.println("第二个interrupted()"+this.interrupted());
                break;
            }
 
        }
        System.out.println("检测到线程中断,线程执行结束");
    }
}
 
public class TestInterrupted {
    public static void main(String[] args) throws InterruptedException {
        TestThread mt = new TestThread();
        mt.start();
        mt.interrupt();
        Thread.sleep(2000);
        System.out.println("mt线程是否存活:" + mt.isAlive());
    }
}


   执行结果如下:

 总结:

interrupt()是给线程设置中断标志
interrupted()是检测中断并清除中断状态
isInterrupted()只检测中断。

还有一点就是interrupted()作用于当前线程,interrupt()和isInterrupted()作用于此线程,即代码中调用此方法的实例所代表的线程。

内容概要:本文深入研究了基于最优滑模控制的永磁同步电机(PMSM)调速系统模型,重点利用Simulink工具搭建并仿真了该控制系统的动态响应特性。文章系统阐述了最优滑模控制策略的设计原理,突出其在削弱传统滑模控制固有抖振现象、增强系统鲁棒性方面的显著优势。通过与传统滑模控制方法的对比实验,充分验证了所提出方法在调速精度、抗外部干扰能力以及动态响应速度等方面的优越性能。研究内容涵盖PMSM数学建模、滑模面构造、最优控制律推导、Lyapunov稳定性分析、参数整定及Simulink仿真验证等完整环节,形成了一套严谨的控制算法设计与实现流程。; 适合人群:具备自动控制原理、现代控制理论基础和MATLAB/Simulink仿真操作能力,从事电机驱动控制、电力电子与电力传动、运动控制或自动化等相关领域研究的工程技术人员及高校研究生。; 使用场景及目标:① 深入掌握滑模控制理论及其在高性能电机调速系统中的具体应用方法;② 学习如何设计并实现能够有效抑制抖振的最优滑模控制器,以提升系统整体鲁棒性和控制品质;③ 利用Simulink平台独立完成从理论建模到仿真验证的全过程,服务于科研课题、课程设计或实际工程项目。; 阅读建议:建议读者务必结合MATLAB/Simulink环境动手复现文中模型,重点关注滑模切换面的设计准则、控制律的数学推导过程以及控制器参数的调节规律,并通过施加不同的负载扰动、设定多种转速指令等方式全面测试系统的动态与稳态性能,从而深刻理解最优滑模控制的核心机理与工程应用价值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值