RFR: CODETOOLS-7903060: jcstress: ProducerConsumer problem sample [v8]

Michael Mirwaldt duke at openjdk.java.net
Fri Dec 10 14:12:11 UTC 2021


> This sample implements some solutions from the wikipedia article about the producer-consumer-problem on https://en.wikipedia.org/wiki/Producer%E2%80%93consumer_problem .
> It contains these solutions:
> - _OneProducerOneConsumer_ with semaphores
> - _FlawedTwoProducersOneConsumer_ with semaphores in which the producers sometimes use the same index for their items and overwrite each others item in the buffer
> - _FixedTwoProducersOneConsumer_ with semaphores which uses an extra lock for the index so that the producers never use the same index for their items
> - _Lock_ doesn't use any sempahores but a reentrant lock with two conditions. It supports many producers and many consumers
> - _AtomicIntegers_ neither uses any semaphores but two atomic integers and supports one producer and one consumer.
> 
> I have decided not to implement the last solution with finite-range single writer registers in the wikipedia article. It looked far too complicated to me.
> 
> This is my third try to avoid squash commits.

Michael Mirwaldt has updated the pull request incrementally with one additional commit since the last revision:

  applied proposals from the fifth review on sample Classic_02_ProducerConsumerProblem

-------------

Changes:
  - all: https://git.openjdk.java.net/jcstress/pull/104/files
  - new: https://git.openjdk.java.net/jcstress/pull/104/files/e34a1820..14a17535

Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jcstress&pr=104&range=07
 - incr: https://webrevs.openjdk.java.net/?repo=jcstress&pr=104&range=06-07

  Stats: 38 lines in 1 file changed: 26 ins; 0 del; 12 mod
  Patch: https://git.openjdk.java.net/jcstress/pull/104.diff
  Fetch: git fetch https://git.openjdk.java.net/jcstress pull/104/head:pull/104

PR: https://git.openjdk.java.net/jcstress/pull/104


More information about the jcstress-dev mailing list