1 L50 Multithreading (2)
2 OBJECTIVES What producer/consumer relationships are and how they are implemented with multithreading.
Producer/Consumer Relationship without Synchronization Producer/consumer relationship – Producer generates data and stores it in shared memory – Consumer reads data from shared memory – Shared memory is called the buffer
4 Outline Buffer.java Fig | Buffer interface used in producer/consumer examples.
5 Outline Producer.java (1 of 2) Implement the runnable interface so that producer will run in a separate thread Declare run method to satisfy interface
6 Outline Producer.java (2 of 2) Sleep for up to 3 seconds
7 Outline Consumer.java (1 of 2) Implement the runnable interface so that producer will run in a separate thread Declare run method to satisfy interface
8 Outline Consumer.java (2 of 2) Sleep for up to 3 seconds
9 Outline Unsynchronized Buffer.java Shared variable to store data Set the value of the bufferRead the value of the buffer
10 Outline SharedBufferTest.java (1 of 4) Create shared UnsynchronizedBuffer for producer and consumer to use
11 Outline SharedBufferTest.java (2 of 4) Pass shared buffer to both producer and consumer
12 Outline SharedBufferTest.java (3 of 4)
13 Outline SharedBufferTest.java (4 of 4)
Producer/Consumer Relationship with Synchronization Producer/consumer relationship – This example uses Lock s and Condition s to implement synchronization
15 Outline SynchronizedBuffer.java (1 of 5) Create ReentrantLock for mutual exclusion Create two Condition variables; one for writing and one for reading Buffer shared by producer and consumer Try to obtain the lock before setting the value of the shared data
16 Outline SynchronizedBuffer.java (2 of 5) Producer waits until buffer is empty
17 Outline SynchronizedBuffer.java (3 of 5) Signal consumer that it may read a value Release lock on shared data Acquire lock before reading a value
18 Outline SynchronizedBuffer.java (4 of 5) Consumer waits until buffer contains data to read
19 Outline SynchronizedBuffer.java (5 of 5) Signal producer that it can write to buffer Release lock on shared data
20 Outline SharedBufferTest2.java (1 of 4) Create SynchronizedBuffer to be shared between producer and consumer
21 Outline SharedBufferTest2.java (2 of 4) Execute the producer and consumer in separate threads
22 Outline SharedBufferTest2.java (3 of 4)
23 Outline SharedBufferTest2.java (4 of 4)
Producer/Consumer Relationship Circular Buffer Circular buffer – Provides extra buffer space into which producer can place values and consumer can read values
25 Outline CircularBuffer.java (1 of 5) Lock to impose mutual exclusionCondition variables to control writing and reading Circular buffer; provides three spaces for data Obtain the lock before writing data to the circular buffer
26 Outline CircularBuffer.java (2 of 5) Wait until a buffer space is empty Update index; this statement imposes the circularity of the buffer Signal waiting thread it can now read data from buffer Release the lock
27 Outline CircularBuffer.java (3 of 5) Lock the object before attempting to read a value Wait for a value to be written to the buffer Update read index; this statement imposes the circularity of the buffer
28 Outline CircularBuffer.java (4 of 5) Signal thread waiting to write to the buffer Release the lock
29 Outline CircularBuffer.java (5 of 5)
30 Outline CircularBufferTest.java (1 of 4) Create CircularBuffer for use in both the producer and consumer Execute the producer and consumer in separate threads
31 Outline CircularBufferTest.java (2 of 4)
32 Outline CircularBufferTest.java (3 of 4)
33 Outline CircularBufferTest.java (4 of 4)
Producer/Consumer Relationship ArrayBlockingQueue ArrayBlockingQueue – Fully implemented version of the circular buffer – Implements the BlockingQueue interface – Declares methods put and take to write and read date from the buffer, respectively
35 Outline BlockingBuffer.java (1 of 2) Create instance of ArrayBlockingQueue to store data Place a value into the buffer; blocks if buffer is full
36 Outline BlockingBuffer.java (2 of 2) Remove value from buffer; blocks if buffer is empty
37 Outline BlockingBufferTest.java (1 of 2) Create BlockingBuffer for use in producer and consumer Execute the producer and consumer in separate threads
38 Outline BlockingBufferTest.java (2 of 2)