Integrated: CODETOOLS-7903060: jcstress: ProducerConsumer problem sample
Michael Mirwaldt
duke at openjdk.java.net
Tue Jan 11 06:46:44 UTC 2022
On Sun, 14 Nov 2021 22:56:25 GMT, Michael Mirwaldt <duke at openjdk.java.net> wrote:
> 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.
This pull request has now been integrated.
Changeset: 0f28604c
Author: Michael Mirwaldt <michael.mirwaldt at gmail.com>
Committer: Aleksey Shipilev <shade at openjdk.org>
URL: https://git.openjdk.java.net/jcstress/commit/0f28604c720e8608718636b1e8aae9ffe7a5a7f1
Stats: 359 lines in 1 file changed: 359 ins; 0 del; 0 mod
7903060: jcstress: ProducerConsumer problem sample
Reviewed-by: shade
-------------
PR: https://git.openjdk.java.net/jcstress/pull/104
More information about the jcstress-dev
mailing list