标签:thread 安全 多线程 同步 synchronized
停止线程
本来Thread类中有一个stop方法可以用来停止线程,但是却过时了,那么又该怎样停止线程呢?
线程运行其实运行的是run方法中的代码,那么只要将run方法停止,那么线程也就随之停止了。
一般线程的运行与循环相结合,那就好办了。将标记修改,那么run方法就会结束。
class StopThread implements Runnable { private boolean flag = true; public void run() { while (flag) { System.out.println(Thread.currentThread().getName() + "-----"); } } public void changeFlag() { flag = false; } } public class Stop { public static void main(String[] args) { int num = 0; StopThread s = new StopThread(); Thread t1 = new Thread(s); Thread t2 = new Thread(s); t1.start(); t2.start(); while (true) { if (num++ == 60) { s.changeFlag(); break; } System.out.println("main"); } } }
但是此方法却不适用于处于冻结状态。
当线程处于冻结状态的时候不会读取到标记,当然不会结束。
当没有指定的方式让冻结的线程恢复到运行状态时,需要对冻结进行清除,强制让线程恢复到运行状态下,这样就可以改变标记,从而让线程结束。
线程在同步中冻结了有怎么结束?Interrupt
API:
public void interrupt()
中断线程。
如果当前线程没有中断它自己(这在任何情况下都是允许的),则该线程的 checkAccess 方法就会被调用,这可能抛出 SecurityException。
如果线程在调用 Object 类的 wait()、wait(long) 或 wait(long, int) 方法,或者该类的 join()、join(long)、join(long, int)、sleep(long) 或 sleep(long, int) 方法过程中受阻,则其中断状态将被清除,它还将收到一个 InterruptedException。
如果该线程在可中断的通道上的 I/O 操作中受阻,则该通道将被关闭,该线程的中断状态将被设置并且该线程将收到一个 ClosedByInterruptException。
如果该线程在一个 Selector 中受阻,则该线程的中断状态将被设置,它将立即从选择操作返回,并可能带有一个非零值,就好像调用了选择器的 wakeup 方法一样。
如果以前的条件都没有保存,则该线程的中断状态将被设置。
中断一个不处于活动状态的线程不需要任何作用。
抛出:
SecurityException - 如果当前线程无法修改该线程
class StopThread implements Runnable { private boolean flag = true; public synchronized void run() { while (flag) { try { wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block // e.printStackTrace(); System.out.println("Exception"); } System.out.println(Thread.currentThread().getName() + "-----"); } } public void changeFlag() { flag = false; } } public class Stop { public static void main(String[] args) { int num = 0; StopThread s = new StopThread(); Thread t1 = new Thread(s); Thread t2 = new Thread(s); t1.start(); t2.start(); while (true) { if (num++ == 60) { // s.changeFlag (); t1.interrupt(); t2.interrupt(); break; } System.out.println("main"); } } }
通过调用interrupt方法,这时线程已经从冻结状态恢复到了运行状态,但是只运行了一次。
使用interrupt会抛出异常,在异常抛出的同时,改变状态,就可以让线程停止。
class StopThread implements Runnable { private boolean flag = true; public synchronized void run() { while (flag) { try { wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block // e.printStackTrace(); System.out.println("Exception"); flag = false; } System.out.println(Thread.currentThread().getName() + "-----"); } } public void changeFlag() { flag = false; } } public class Stop { public static void main(String[] args) { int num = 0; StopThread s = new StopThread(); Thread t1 = new Thread(s); Thread t2 = new Thread(s); t1.start(); t2.start(); while (true) { if (num++ == 60) { // s.changeFlag (); t1.interrupt(); t2.interrupt(); break; } System.out.println("main"); } } }
标签:thread 安全 多线程 同步 synchronized
原文地址:http://blog.csdn.net/u013476556/article/details/43058297