Java并发09-stop方法和suspend方法

本文探讨了如何在Java中安全地暂停和恢复线程,以避免使用stop、suspend方法导致的问题。通过引入volatile变量和ReentrantLock的Condition,可以在确保线程安全的同时实现线程的挂起和恢复。示例代码展示了如何使用condition的await和signalAll方法在同步块中协调线程状态,从而避免死锁并确保对象一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

stop方法会终止所有未结束的方法,包括run方法。当线程被终止时,立刻释放被它锁住的所有对象的锁
这会导致对象处于不一致的状态
(转账转了一半被终止)
suspend方法不会破坏对象,但是对于持有锁的线程,调用suspend方法并不会释放锁,如果调用suspend方法的线程试图获得同一个锁,那么程序死锁。
被挂起的线程等待被恢复,将其挂起的线程等待获得锁

如果想安全地挂起(暂停)一个线程,需要引入一个变量suspendRequested,并在run方法的安全地方测试它,安全指的是同步块之外。
当该线程发现suspendRequested变量已被设置,那么会保持等待直至它再次获得为止
示例:

public class SuspendTest implements Runnable{
	private volatile boolean suspendRequested = false; //指示是否要求暂停
	private Lock suspendLock = new ReentrantLock();
	private Condition suspendCondition = suspendLock.newCondition();
	@Override
	public void run() {
		while(/*true*/){
			//...
			if(suspendRequested) {//如果请求暂停线程
				suspendLock.lock(); 
				try {
					while(suspendRequested) { //当仍处于暂停状态时,await
						suspendCondition.await();
					}
				}finally {
					suspendLock.unlock();
				}
			}
		}
	}
	
	public void requestSuspend() {
		this.suspendRequested = true;
	}
	
	public void requestResume() {
		this.suspendRequested = false;
		suspendLock.lock();
		try {
			suspendCondition.signalAll();
		}finally {
			suspendLock.unlock();
		}
	}
}

await和signalAll方法都是在同步块中调用的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值