Java停止线程的几种方法

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修饰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值