1. interruput()
this.interrupted():测试当前线程是否中断
测试当前线程是否已经中断,但会清除当前线程的中断状态,第二次调用会返回false.
--------------------------------------------
this.isInterruputed():测试线程是否中断
测试当前线程是否已经是中断状态,但不清除状态标志。
此方法并不会真正终止线程的执行,仅仅给jvm一个中断标记,具体什么时候中断,取决于jvm。
2. 异常法停止线程(推荐使用)
throw new InterruptedException();
3 sleep()与interrupt()方法一起使用
会报java.lang.InterruptedException()异常
4. stop()
暴力法终止线程,已废弃。
1.不推荐使用
2.会对锁对象“解锁”,导致数据不安全的同步问题
3.会产生java.lang.ThreadDeath()异常
5. return 方法
不建议使用,代码中出现多个return;造成污染
6. 暂停线程方法
suspend():无法控制线程内部代码持有的锁的释放
resume():
缺点1:如果使用不当,极易造成公共的同步对象的独占,使得其他线程无法访问公共同步对象。
2.因为线程的暂停而导致数据不同步的情况。
7. yield
放弃当前的CPU资源,将它让给其他的任务去占用CPU执行权。但放弃的时间不确定,有时候刚刚放弃,马上又获得CPU时间权。
8.使用volatile开关控制
由于线程interrupt标识很有可能被擦除,或者逻辑单元不会调用任何可中断方法,所以使用volatile修饰的开关flag关闭线程也是一种常用的做法。
public class Test {
static class MyTask extends Thread{
private volatile boolean closed = false;
public void run() {
System.out.println("I will start work");
while(!closed&&!isInterrupted()) {
}
System.out.println("end work");
}
public void close() {
this.closed = true;
this.interrupt();
}
}
public static void main(String[] args) throws InterruptedException {
MyTask t = new MyTask();
t.start();
TimeUnit.MINUTES.sleep(1);
System.out.println("System will be shutdown");
t.close();
}
}
运行结果:
I will start work
System will be shutdown
end work
上面的结果是定义了一个开关变量closed,并且是使用volatile修饰。