java多线—Lock关键字
一.简介
Lock就像synchronized块一样也是线程同步机制,但Lock比synchronized更复杂。Lock以及其他更高级的同步机制都是synchronized块的扩展,因此我们讲Lock的时候不能完全摆脱synchronized关键字。
二.Lock的使用
在讲synchronized关键字时,我们用了下面的代码作为同步的例子:
public class Counter{
private int count = 0;
public synchronized void add(int value){
this.count += value;
}
}
下面我们改为用Lock同步,代码如下:
public class Counter{
private lock lock = new ReentrantLock();
private int count = 0;
public void add(int value){
lock.lock();
this.count += value;
lock.unlock();
}
}
三.读写锁
读写锁(ReadWriteLock)是一种高级线程锁定机制,它允许多个线程同时读取某个资源。但写锁是独占的。代码如下:
ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
readWriteLock.readLock().lock();
//读取资源,这里多个线程可同时执行,但对写入来说,是锁定的
readWriteLock.readLock().unlock();
readWriteLock.writeLock().lock();
//写入资源,这里是独占的
readWriteLock.writeLock().unlock();
}
三.公平锁
Java的同步块不保证线程被授予访问权限的顺序,因此,如果许多线程不断竞争访问同一个同步块,则存在一个或多个线程永远不被授予访问权限的风险,为了避免这种情况,可以使用Lock。