- Java Concurrency Utilities - java.util.concurrent
- Java BlockingQueue
- Java ExecutorService
- Java Callable
- Java Future
- Java Fork and Join using ForkJoinPool
- Java Lock
java.util.concurrent.locks.ReadWriteLock is an advanced thread lock mechanism.
It allows multiple threads to read a certain resource, but only one to write it, at a time.
The idea is, that multiple threads can read from a shared resource without causing concurrency errors. The concurrency errors first occur when reads and writes to a shared resource occur concurrently, or if multiple writes take place concurrently.
In this text I only cover Java's built-in
ReadWriteLock. If you want to read more
about the theory behind the implemenation of a ReadWriteLock, you can read it in my
Read Write Locks in my Java Concurrency
ReadWriteLock Locking Rules
The rules by which a thread is allowed to lock the
ReadWriteLock either for reading or
writing the guarded resource, are as follows:
|Read Lock||If no threads have locked the |
and no thread have requested a write lock (but not yet obtained it).
Thus, multiple threads can lock the lock for reading.
|If no threads are reading or writing. |
Thus, only one thread at a time can lock the lock for writing.
ReadWriteLock is an interface. Thus, to use a
java.util.concurrent.locks package contains the following
ReadWriteLock Code Example
Here is a simple code example that shows how to create a
ReadWriteLock and how to
lock it for reading and writing:
ReadWriteLock readWriteLock = new ReentrantReadWriteLock(); readWriteLock.readLock().lock(); // multiple readers can enter this section // if not locked for writing, and not writers waiting // to lock for writing. readWriteLock.readLock().unlock(); readWriteLock.writeLock().lock(); // only one writer can enter this section, // and only if no threads are currently reading. readWriteLock.writeLock().unlock();
Notice how the
ReadWriteLock actually internally keeps two
instances. One guarding read access, and one guarding write access.