`
跑龙套_az
  • 浏览: 7730 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

java.util.concurrent(二) Lock

 
阅读更多

           在多线程编程中常常需要进行同步而锁定某个对象,通常采用synchronized来实现,部分情况下采用Java.util.concurrent.lock更加合适。ReentrantLock实现了Lock接口、是常用的实现类。

           

           Lock和synchronized有个明显的区别在于----lock必须在finally里面释放,如若不在finally中释放,则操作中抛出异常、锁又可能永远得不到释放,这点非常重要。

 

Lock lock = new ReentrantLock();
lock.lock();
try {
     // ...
} 
finally {
     lock.unlock();
}

 

 

          Lock的Condition使得Lock在使用的时候更加的灵活。Lock与synchronized的功能类似、进行同步,Condition则用于线程间通信、其提供的await()、signal()方法相对于wait()、notify()方法。condition与Lock绑定使用、一个Lock可通过Lock.newCondition()方法绑定多个condition,即相当于同一个锁有多个等待队列。相比较于synchronized灵活许多。下面以典型的生产者-消费者问题为例做个比较:

package producerConsumer;

import java.util.LinkedList;
import java.util.Queue;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

import producerConsumer.ProducerConsumer.Consumer;
import producerConsumer.ProducerConsumer.Producer;

public class ProducerConsumerLock {
	private static Queue<Object> myList = new LinkedList<Object>();
	private static final int MAX = 1;
	private static Lock lock = new ReentrantLock();
	private static Condition full = lock.newCondition();
	private static Condition empty = lock.newCondition();
	
	public static void main(String[] args) {
		for(int i = 0; i < 10; i++) {
			new Thread(new Producer(), "Producer" + i).start();
			new Thread(new Consumer(), "Consumer" + i).start();
		}
	}
	
	static class Producer extends Thread {
		public void run() {
			while(true) {
				lock.lock();
				try {
					while(myList.size() == MAX) {
						System.out.println("queue is full...");
						full.await();
					}
					Thread.currentThread().sleep(Math.round(100));
					Object o = new Object();
					myList.add(o);
					System.out.println("Producer-MQsize: " + myList.size() + "       name: " + Thread.currentThread().getName());
					empty.signal();
				} catch(Exception e) {
					e.printStackTrace();
				} finally {
					lock.unlock();
				}
			
			}
		}
	}
	
	static class Consumer extends Thread {
		public void run() {
			while(true) {
				lock.lock();
				try {
					while(myList.size() == 0) {
						System.out.println("queue is empty...");
						empty.await();
					}
					Thread.currentThread().sleep(Math.round(1000));
					Object o = myList.remove();
					System.out.println("Consumer-MQsize: " + myList.size() + "       name: " + Thread.currentThread().getName());
					full.signal();
				} catch(Exception e) {
					e.printStackTrace();
				} finally {
					lock.unlock();
				}
			}
		}
	}
}

 

           ReentrantLock通过其构造器的参数设置,可实现公平锁的功能,公平锁使线程按照请求锁的顺序依次获得锁。公平锁的性能开销非常大,因此ReentrantLock的默认设置时不公平的,除非公平对你的算法非常重要、必须严格按照线程排队的顺序进行服务,除此之外一般都不采用公平锁。

Lock lock = new ReentrantLock(false);//设置为true则为公平锁

 

          Lock的tryLock()也是一大特征、尝试获得锁,该方法立即返回结果、也可设置等待时间。

          Lock的性能方面表现也比synchronized优异,但是一般情况下不使用Lock。Lock与synchronized的具体区别以及选择如下 :http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html

分享到:
评论

相关推荐

    java并发工具包 java.util.concurrent中文版用户指南pdf

    1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...

    java.util.concurrent 学习ppt

    Java.util.concurrent是Java 5.0引入的一个重要包,它为多线程编程提供了一组高级并发工具。这个包的设计者是Doug Lea,它的出现是JSR-166的一部分,也被称作Tiger更新。Java.util.concurrent的引入是为了解决传统...

    Java并发工具包java.util.concurrent用户指南中英文对照阅读版.pdf

    java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...

    The java.util.concurrent Synchronizer Framework

    ### Java.util.concurrent同步器框架详解 #### 概述 Java平台在J2SE 1.5版本中引入了`java.util.concurrent`包,这是一系列中等层次的并发支持类集合,通过Java社区过程(Java Community Process, JCP)的Java规范...

    深入Synchronized和java.util.concurrent.locks.Lock的区别详解

    《深入Synchronized与java.util.concurrent.locks.Lock的区别详解》 Synchronized和java.util.concurrent.locks.Lock都是Java中用于实现线程同步的关键字和接口,它们的主要目标是保证多线程环境下的数据一致性与...

    java.util.concurrent-多线程框架.docx

    在 java.util.concurrent 多线程框架中,还提供了多种其他机制,包括并发集合、同步器、lock 等,以便开发者更方便地编写高效、可靠的多线程程序。并发集合提供了多种机制,包括 CopyOnWriteArrayList、...

    Java并发工具包java.util.concurrent用户指南中英文对照阅读版

    本资源包含两个 pdf 文档,一本根据 Jakob Jenkov 最新博客 (http://tutorials.jenkov.com/java-util-concurrent/index.html) 整理的 java_util_concurrent_user_guide_en.pdf,一个中文翻译的 java_util_concurrent...

    java.util.concurrent介绍(重要).pdf

    总之,`java.util.concurrent` 提供的工具使得并发编程变得更加容易和高效,是 Java 并发编程的基石,无论是对于初学者还是经验丰富的开发者,理解和掌握这个包都是非常重要的。通过熟练运用这些工具,开发者可以...

    Redis客户端Redisson.zip

    java.util.SortedSet 分布式 java.util.Queue 分布式 of java.util.Deque 分布式 java.util.Map 分布式 java.util.concurrent.ConcurrentMap 通过TTL实现可重入 java.util.concurrent.locks.Lock 分布式 ...

    28个java常用的工具类

    23. **`java.util.concurrent.locks.Lock`** 和 **`java.util.concurrent.locks.ReentrantLock`**: 锁机制,用于线程同步。 24. **`java.util.ArrayList`**: 用于创建堆栈、队列和双端队列的实现,如`ArrayDeque`。...

    基于线程池的Java多线程应用技术.pdf

    Java提供了两种方式实现线程同步机制,分别是使用synchronized关键字和java.util.concurrent.locks.Lock接口。 线程池的应用: 线程池技术可以应用于Web服务系统中,控制服务器系统的最大并发数与最多处理的任务数...

    backport-util-concurrent(2.2 /3.1)

    《backport-util-concurrent:Java并发编程的利器》 在Java的世界里,高效并发处理是提升应用程序性能的关键因素之一。backport-util-concurrent库,正如其名,是一种将Java 5及以上版本的并发特性“回移植”到Java...

    java 资源搜索并下载(线程等待和通报)

    Java的`java.util.concurrent.locks.Condition`接口提供了这一功能。线程可以通过`await()`方法进入等待状态,直到收到`signal()`或`signalAll()`通知后唤醒。这在资源下载完成后更新进度或通知用户时非常有用。 五...

    redis-lock-master.zip

    分布式锁与信号量 包含测试用例和实验的JAVA代码 ... ... import com.example.springbootdemo.commons.lock.DistributedLock; import org.junit.Test;...import java.util.concurrent.*; @RunWith(SpringRunner.cla

    Java_JUC_Study:java.util.concurrent代码示例学习

    Java并发编程是Java开发中的重要领域,特别是在多线程应用中,`java.util.concurrent`(JUC)包提供了丰富的工具类和接口,帮助开发者高效、安全地管理并发任务。本项目"Java_JUC_Study"显然是一个针对这个关键包的...

    SimpleDateFormat线程不安全的5种解决方案.docx

    import java.util.concurrent.locks.ReentrantLock; public class SimpleDateFormatExample { private static SimpleDateFormat simpleDateFormat = new SimpleDateFormat("mm:ss"); private static Lock lock = ...

    Java常用类总结

    `java.util.concurrent`包是处理多线程和并发的重要工具。`ExecutorService`、`Future`和`Callable`接口,以及`Thread`类,共同构成了Java的并发框架。例如,`ThreadPoolExecutor`可以管理一组工作线程来执行任务,...

    java多线程编程总结

    - `java.util.concurrent.locks.Lock`接口提供了比`synchronized`更灵活的锁定机制。 #### 六、Java多线程的高级特性 ##### 1. 线程池 - `java.util.concurrent.ExecutorService`接口提供了一种重用固定数量的线程...

    java多线程实现生产者和消费者

    `java.util.concurrent.locks.Condition` 接口与 `java.util.concurrent.locks.Lock` 接口一起使用,提供了比`synchronized`更细粒度的控制。Lock提供了获取和释放锁的方法,而Condition则允许线程等待特定条件并被...

    juconcurrent:java.util.concurrent

    Java JUC的使用1.volatile关键字-内存可见性2.原子变量-CAS算法3.ConcurrentHashMap锁分段机制4.CountDownLatch闭锁5.实现Callable接口6.Lock同步锁7.Condition控制线程通信8.线程按序交替9.ReadWriteLock读写锁10....

Global site tag (gtag.js) - Google Analytics