Thread类的interrupt(),interrupted(),isInterrupted()

1. sleep() & interrupt() 
线程A正在使用sleep()暂停着: Thread.sleep(100000); 
若是要取消他的等待状态,能够在正在执行的线程里(好比这里是B)调用 
a.interrupt(); 
令线程A放弃睡眠操做,这里a是线程A对应到的Thread实例 
执行interrupt()时,并不须要获取Thread实例的锁定.任何线程在任什么时候刻,均可以调用其余线程interrupt().当sleep中的线程被调用interrupt()时,就会放弃暂停的状态.并抛出InterruptedException.丢出异常的,是A线程.

2. wait() & interrupt() 
线程A调用了wait()进入了等待状态,也能够用interrupt()取消. 
不过这时候要当心锁定的问题.线程在进入等待区,会把锁定解除,当对等待中的线程调用interrupt()时(注意是等待的线程调用其本身的interrupt()),会先从新获取锁定,再抛出异常.在获取锁定以前,是没法抛出异常的.

3. join() & interrupt() 
当线程以join()等待其余线程结束时,同样可使用interrupt()取消之.由于调用join()不须要获取锁定,故与sleep()时同样,会立刻跳到catch块里.注意是随调用interrupt()方法,必定是阻塞的线程来调用其本身的interrupt方法.如在线程a中调用来线程t.join().则a会等t执行完后在执行t.join后的代码,当在线程b中调用来a.interrupt()方法,则会抛出InterruptedException

4. interrupt()只是改变中断状态而已 测试

interrupt()不会中断一个正在运行的线程。这一方法实际上完成的是,在线程受到阻塞时抛出一个中断信号,这样线程就得以退出阻塞的状态。线程

更确切的说,若是线程被Object.wait, Thread.join和Thread.sleep三种方法之一阻塞,那么,它将接收到一个中断异常(InterruptedException),从而提前地终结被阻塞状态。
若是线程没有被阻塞,这时调用interrupt()将不起做用;code

若是线程没有被阻塞,这时调用interrupt()将不起做用; 
线程A在执行sleep,wait,join时,线程B调用A的interrupt方法,的确这一个时候A会有InterruptedException异常抛出来.但这实际上是在sleep,wait,join这些方法内部会不断检查中断状态的值,而本身抛出的InterruptedException。
若是线程A正在执行一些指定的操做时如赋值,for,while,if,调用方法等,都不会去检查中断状态,因此线程A不会抛出InterruptedException,而会一直执行着本身的操做.当线程A终于执行到wait(),sleep(),join()时,才立刻会抛出InterruptedException.
若没有调用sleep(),wait(),join()这些方法,或是没有在线程里本身检查中断状态本身抛出InterruptedException的话,那InterruptedException是不会被抛出来的.it

 

 

public void interrupt()

中断线程。io

若是当前线程没有中断它本身(这在任何状况下都是容许的),则该线程的 checkAccess 方法就会被调用,这可能抛出 SecurityException方法

若是线程在调用 Object 类的 wait()wait(long) 或wait(long, int) 方法,或者该类的join()join(long)join(long, int)sleep(long) 或 sleep(long, int) 方法过程当中受阻,则其中断状态将被清除,它还将收到一个InterruptedException。  异常

 

 

 

 

public boolean isInterrupted()

测试线程是否已经中断。线程的中断状态 不受该方法的影响。static

线程中断被忽略,由于在中断时不处于活动状态的线程将由此返回 false 的方法反映出来。while

 

返回:co

若是该线程已经中断,则返回 true;不然返回 false

 

 

 

public static boolean interrupted()

测试当前线程是否已经中断。线程的中断状态 由该方法清除。换句话说,若是连续两次调用该方法,则第二次调用将返回 false(在第一次调用已清除了其中断状态以后,且第二次调用检验完中断状态前,当前线程再次中断的状况除外)。

线程中断被忽略,由于在中断时不处于活动状态的线程将由此返回 false 的方法反映出来。

 

返回:

若是当前线程已经中断,则返回 true;不然返回 false

相关文章
相关标签/搜索