同步锁的另外一种实现

代码摘自《Java 线程》


public class BusyFlag {
	protected Thread busyFlag = null;
	
	public void getBusyFlag() {
		while (busyFlag != Thread.currentThread()) {
			if (busyFlag == null) {
				busyFlag = Thread.currentThread();
			}
			try {
				Thread.sleep(100);
			} catch (Exception e) {
				// TODO: handle exception
			}
		}
	}
	
	public void freeBusyFlag() {
		if (busyFlag == Thread.currentThread()) {
			busyFlag = null;
		}
	}
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 一些实现同步机制的方式包括:使用锁、信号量、条件变量、屏障等。锁可以用于保护共享资源,信号量可以用于限制并发访问,条件变量可以用于线程之间的通信,屏障可以用于同步多个线程的执行。具体实现方式取决于具体的应用场景和需求。 ### 回答2: 实现同步机制的几种方式包括:锁机制、信号量机制、条件变量机制和管程机制。 锁机制是最常见的同步机制,通过对关键资源加锁来实现同一时间只能有一个线程访问该资源。常见的锁包括互斥锁和读写锁。互斥锁用于实现互斥访问,即同一时间只能有一个线程访问该资源;读写锁则允许多个线程同时读取资源,但只允许一个线程写入资源。 信号量机制使用信号量来实现对资源的访问控制。它通过一个计数器来控制同一时间内允许访问资源的线程数量,并提供了P操作(申请访问资源)和V操作(释放资源)来实现对资源的加锁和解锁。 条件变量机制用于实现线程之间的通信和协作。它通过一个条件变量和一个互斥锁来实现线程可以在某个条件成立时等待条件变量,直到条件满足后被唤醒;同时,其他线程也可以通过发送信号来通知条件变量的等待线程条件已经满足。 管程机制是一种高级的同步机制,它将共享资源和对资源的操作封装在一个对象中,通过对象的方法实现资源的访问控制。管程提供了条件变量和互斥锁来实现线程之间的通信和同步操作。 这些同步机制都可以用来解决多线程并发访问共享资源时可能引发的问题,例如数据竞争和死锁。不同的机制适用于不同的场景和需求,开发者需要根据实际情况选择合适的同步机制来确保程序的正确性和性能。 ### 回答3: 实现同步机制的几种方式有: 1. 互斥量(Mutex):使用互斥量来保证同一时间只有一个线程执行临界区代码,通过对互斥量的加锁和解锁来控制线程的访问顺序。 2. 信号量(Semaphore):使用信号量来控制同时可访问某一资源的线程数量,通过信号量的P(wait)和V(signal)操作来进行进程间的同步。 3. 条件变量(Condition):条件变量用于在某个线程等待特定条件的发生,当条件满足时,其他线程可以唤醒等待的线程继续执行。 4. 临界区(Critical Section):临界区是指一段代码,一次只允许一个线程进入执行,通过使用互斥量或信号量来保证临界区的互斥性。 5. 事件(Event):事件用于线程间的通信和同步,一个线程等待某个事件的发生,另一个线程发生该事件后,等待的线程被唤醒继续执行。 6. 互斥量+条件变量(Mutex+Condition):通过互斥量的加锁和解锁保证临界区的互斥性,通过条件变量的等待和唤醒来控制线程的执行顺序和同步。 以上是实现同步机制的几种常见方式,不同的应用场景可以选择适合的方式来实现线程间的同步和互斥操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值