java基础——多线程(锁lock&&条件阻塞Condition)

本文详细介绍了Java中的Lock接口以及条件阻塞Condition的使用。Lock提供了比synchronized更灵活的线程同步机制,它使得锁更加面向对象。在讲解中,通过实例演示了如何使用Lock实现线程同步通信,以及Condition在多路等待和通知中的应用。文章还提到了虚假唤醒的可能性,并强调在实践中应始终在循环中等待并检查等待状态。
摘要由CSDN通过智能技术生成

一、Lock实现线程同步通信

1、Lock比传统线程模型中的synchronized方式更加面向对象,与生活中的锁类似,锁本身也应该是一个对象。两个线程执行的代码片段要实现同步互斥的效果,它们必须用同一个Lock对象。

 class Output{
	 //1、实例化一把锁,但Lock是个接口,要用ReentrantLock作为实现类
	 Lock lock = new ReentrantLock();
	public void output1(String a){
		int len = a.length();
		lock.lock();//2、把所要锁起来的程序加锁
		try {
			for (int i = 0; i < len; i++) {
				System.out.print(a.charAt(i));//打印每个字母
			}
		} finally {
			lock.unlock(); //3、在finally里面打开锁
		}
		System.out.println();
	}
}

2、读写锁:分为读锁和写锁,多个读锁不互斥,读锁与写锁互斥,这是由jvm自己控制的,你只要上好相应的锁即可。如果你的代码只读数据,可以很多人同时读,但不能同时写,那就上读锁;如果你的代码修改数据,只能有一个人在写,且不能同时读取,那就上写锁。总之,读的时候上读锁,写的时候上写锁!

1)下面是jdk配的Demo

class CachedData {
   Object data;
   volatile boolean cacheValid;
   final ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();//读写锁实例

   void processCachedData() {
     rwl.readLock().lock(); //1、一开始假设有数据,上读锁
     if (!cacheValid) {//判断是否有数据,有跳2、;没有跳4、
        // Must release read lock before acquiring write lock
        rwl.readLock().unlock(); //4、解读锁上写锁
        rwl.writeLock().lock();
        try {
          // Recheck state because another thread might have
          // acquired write lock and changed state before we did.
          if (!cacheValid) {
            data = ...  //5、写数据
            cacheValid = true;
          }
          // Downgrade by acquiring read lock before releasing write lock
          rwl.readLock().lock(); //6、上读锁,解写锁
        } finally {
          rwl.writeLock().unlock(); // Unlock write, still hold read
        }
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值