siteName > > reader-writer-lock
Threads
java ( 325737 ) - com.iluwatar.re ( 326196 ) stack: com.iluwatar.reader.writer.lock.App.main(App.java:56) org.codehaus.mojo.exec.ExecJavaMojo.doMain(ExecJavaMojo.java:385) org.codehaus.mojo.exec.ExecJavaMojo.doExec(ExecJavaMojo.java:374) org.codehaus.mojo.exec.ExecJavaMojo.lambda$execute$0(ExecJavaMojo.java:296) java.base/java.lang.Thread.run(Thread.java:840)
/*
 * This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
 *
 * The MIT License
 * Copyright © 2014-2022 Ilkka Seppälä
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package com.iluwatar.reader.writer.lock;

import java.util.concurrent.Executors;
import java.util.concurrent.ThreadLocalRandom;
import java.util.concurrent.TimeUnit;
import lombok.extern.slf4j.Slf4j;

/**
 * In a multiple thread applications, the threads may try to synchronize the shared resources
 * regardless of read or write operation. It leads to a low performance especially in a "read more
 * write less" system as indeed the read operations are thread-safe to another read operation.
 *
 * <p>Reader writer lock is a synchronization primitive that try to resolve this problem. This
 * pattern allows concurrent access for read-only operations, while write operations require
 * exclusive access. This means that multiple threads can read the data in parallel but an exclusive
 * lock is needed for writing or modifying data. When a writer is writing the data, all other
 * writers or readers will be blocked until the writer is finished writing.
 *
 * <p>This example use two mutex to demonstrate the concurrent access of multiple readers and
 * writers.
 *
 * @author hongshuwei@gmail.com
 */
@Slf4j
public class App {

  /**
   * Program entry point.
   *
   * @param args command line args
   */
  public static void main(String[] args) {

    var executeService = Executors.newFixedThreadPool(10);
    var lock = new ReaderWriterLock();

    // Start writers
    for (var i = 0; i < 5; i++) {
      var writingTime = ThreadLocalRandom.current().nextLong(5000);
      executeService.submit(new Writer("Writer " + i, lock.writeLock(), writingTime));
    }
    LOGGER.info("Writers added...");

    // Start readers
    for (var i = 0; i < 5; i++) {
      var readingTime = ThreadLocalRandom.current().nextLong(10);
      executeService.submit(new Reader("Reader " + i, lock.readLock(), readingTime));
    }
    LOGGER.info("Readers added...");

    try {
      Thread.sleep(5000L);
    } catch (InterruptedException e) {
      LOGGER.error("Error sleeping before adding more readers", e);
      Thread.currentThread().interrupt();
    }

    // Start readers
    for (var i = 6; i < 10; i++) {
      var readingTime = ThreadLocalRandom.current().nextLong(10);
      executeService.submit(new Reader("Reader " + i, lock.readLock(), readingTime));
    }
    LOGGER.info("More readers added...");


    // In the system console, it can see that the read operations are executed concurrently while
    // write operations are exclusive.
    executeService.shutdown();
    try {
      executeService.awaitTermination(5, TimeUnit.SECONDS);
    } catch (InterruptedException e) {
      LOGGER.error("Error waiting for ExecutorService shutdown", e);
      Thread.currentThread().interrupt();
    }

  }

}
Variables All
No.FromNameValue
1class@56LOGGERLogger[com.iluwatar.reader.writer.lock.App]
256args[Ljava.lang.String;@6305147a
END 0 00
Output All Filter Merge
Process FilterThread Filter
325737 java 326239 pool-1-thread-1 326243 pool-1-thread-5 326196 com.iluwatar.re 326252 pool-1-thread-9 326253 pool-1-thread-1 326242 pool-1-thread-4 326250 pool-1-thread-7 326251 pool-1-thread-8 326240 pool-1-thread-2 326241 pool-1-thread-3 326245 pool-1-thread-6
No.PNPIDTIDTNTLMessage
1java325737326239pool-1-thread-1com.iluwatar.reader.writer.lock.WriterIWriter 0 begin
2java325737326196com.iluwatar.recom.iluwatar.reader.writer.lock.AppIWriters added...
3java325737326196com.iluwatar.recom.iluwatar.reader.writer.lock.AppIReaders added...
4java325737326239pool-1-thread-1com.iluwatar.reader.writer.lock.WriterIWriter 0 finished after writing 3512ms
5java325737326240pool-1-thread-2com.iluwatar.reader.writer.lock.WriterIWriter 1 begin
6java325737326240pool-1-thread-2com.iluwatar.reader.writer.lock.WriterIWriter 1 finished after writing 859ms
7java325737326253pool-1-thread-1com.iluwatar.reader.writer.lock.ReaderIReader 4 begin
8java325737326252pool-1-thread-9com.iluwatar.reader.writer.lock.ReaderIReader 3 begin
9java325737326245pool-1-thread-6com.iluwatar.reader.writer.lock.ReaderIReader 0 begin
10java325737326250pool-1-thread-7com.iluwatar.reader.writer.lock.ReaderIReader 1 begin
11java325737326251pool-1-thread-8com.iluwatar.reader.writer.lock.ReaderIReader 2 begin
12java325737326250pool-1-thread-7com.iluwatar.reader.writer.lock.ReaderIReader 1 finish after reading 0ms
13java325737326252pool-1-thread-9com.iluwatar.reader.writer.lock.ReaderIReader 3 finish after reading 2ms
14java325737326245pool-1-thread-6com.iluwatar.reader.writer.lock.ReaderIReader 0 finish after reading 3ms
15java325737326251pool-1-thread-8com.iluwatar.reader.writer.lock.ReaderIReader 2 finish after reading 2ms
16java325737326253pool-1-thread-1com.iluwatar.reader.writer.lock.ReaderIReader 4 finish after reading 9ms
17java325737326242pool-1-thread-4com.iluwatar.reader.writer.lock.WriterIWriter 3 begin
18java325737326196com.iluwatar.recom.iluwatar.reader.writer.lock.AppIMore readers added...
19java325737326242pool-1-thread-4com.iluwatar.reader.writer.lock.WriterIWriter 3 finished after writing 4506ms
20java325737326243pool-1-thread-5com.iluwatar.reader.writer.lock.WriterIWriter 4 begin
21java325737326243pool-1-thread-5com.iluwatar.reader.writer.lock.WriterIWriter 4 finished after writing 4852ms
22java325737326239pool-1-thread-1com.iluwatar.reader.writer.lock.ReaderIReader 6 begin
23java325737326252pool-1-thread-9com.iluwatar.reader.writer.lock.ReaderIReader 9 begin
24java325737326250pool-1-thread-7com.iluwatar.reader.writer.lock.ReaderIReader 8 begin
25java325737326240pool-1-thread-2com.iluwatar.reader.writer.lock.ReaderIReader 7 begin
26java325737326240pool-1-thread-2com.iluwatar.reader.writer.lock.ReaderIReader 7 finish after reading 1ms
27java325737326239pool-1-thread-1com.iluwatar.reader.writer.lock.ReaderIReader 6 finish after reading 9ms
28java325737326252pool-1-thread-9com.iluwatar.reader.writer.lock.ReaderIReader 9 finish after reading 8ms
29java325737326250pool-1-thread-7com.iluwatar.reader.writer.lock.ReaderIReader 8 finish after reading 7ms
30java325737326241pool-1-thread-3com.iluwatar.reader.writer.lock.WriterIWriter 2 begin
31java325737326241pool-1-thread-3com.iluwatar.reader.writer.lock.WriterIWriter 2 finished after writing 2761ms
END 0 0 0 0 0 00
Project:JavaDesignPatterns
Update:20240509
Commit:bf6456ba6
Source Code:reader-writer-lock
BuildTool:Java17
Compiler:Java17
Runtime:Openjdk17
System:MySystemD
Kernel:Linux5.10.211
Cpu:Intel:Corei7-7700K
Machine:AwesomeMachine