`
跑龙套_az
  • 浏览: 7273 次
  • 性别: 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并发工具包java.util.concurrent用户指南中英文对照阅读版.pdf

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

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

    本篇文章是对Synchronized和java.util.concurrent.locks.Lock的区别进行了详细的分析介绍,需要的朋友参考下

    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...

    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 分布式 ...

    juconcurrent:java.util.concurrent

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

    Java基础知识点总结.docx

    无论是工作学习,不断的总结是必不可少的。只有不断的总结,发现问题,弥补不足,才能长久的...java.util.concurrent.locks包下常用的类 326 NIO(New IO) 327 volatile详解 337 Java 8新特性 347 Java 性能优化 362

    java并发工具包详解

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

    java并发包资源

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

    多线程,高并发.pdf

    1. stop() 和 suspend() 方法为何不推荐使用? 2. sleep() 和 wait() 有什么区别? 3. 同步和异步有何异同,...5. 简述 synchronized 和 java.util.concurrent.locks.Lock 的异同? 6. 概括的解释下线程的几种可用状态。

    zp-concurrent-lib:我自己编写的一些高性能并发库

    zp-concurrent-lib 自己写的一些java高级并发类库 功能介绍 ...com.lzp.util.concurrent.blockingQueue.withlock com.lzp.util.concurrent.blockingQueue.lockless com.lzp.util.concurrent.latch com.

    Redisson-官方文档中文翻译.pdf

    Java Redis 客户端,它不只是一个简单的 Redis 客户端,而是一个以内存 Redis 服务器作为后端的处理 Java 对象(如 java.util.List、java.util.Map、java.util.Set、java.util.concurrent.locks.Lock 等)的框架。...

    华为IBM的java面试题

    33.简述synchronized和java.util.concurrent.locks.Lock的异同 ? 34.EJB规范规定EJB中禁止的操作有哪些? 35.java除了8种基本类型外,在虚拟机里还有哪一种,有什么作用? 36.除了使用new关键字创建对象意外,试列举...

    java 并发编程 多线程

    java 并发 编程 多线程 concurrent lock condition executorserice executor java.util.curcurrent.

    125道经典JAVA面试题

    面向对象的特征有哪些方面?运行时异常与一般异常有何异同?简述synchronized和java.util.concurrent.locks.Lock的异同?等等面试题。。。。。

    浅析Java_Concurrency

    着重介绍了java.util.concurrent.*下边的各个接口及类的功能及应用场景。

    petsClinicV6WithThreads

    Реализованочерезjava.util.concurrent.locks.ReentrantLock например: public void add(final Person person) { final ReentrantLock lock = this.lock; lock.lock(); try { ...

    java8源码-JUC:日常使用进程/线程的案例或者case

    java8 源码 #juc多线程 java.util.concurrent(并发) ##概念复习 进程:正在进行中的程序 线程:进程当中的一个执行单元 关系: 进程包含线程 面试问题: 日常使用进程/线程的案例或者case ###线程的各种状态: ...lock.loc

    java核心知识点整理.pdf

    25 JAVA8 与元数据.................................................................................................................................25 2.4. 垃圾回收与算法 .................................

    基于Java多线程同步的安全性研究

    解决Java多线程同步的方法是在需要同步的方法签名中加入synchronized关键字,使用synchronized对需要进行同步的代码段进行同步,或使用JDK 5中提供的java.util.concurrent.lock包中的Lock对象。为解决多个线程对同一...

Global site tag (gtag.js) - Google Analytics