multithreading, JAVA Programming

Assignment Help:
For this assignment we will be solving the producer-consumer problem with a bounded buffer. You are required to implement this assignment in Java. There are three components in this assignment.

(1) The Bounded Buffer: This buffer can hold a fixed number of items. The number of elements in this buffer is limited to 1000. This buffer needs to be a first-in first-out (FIFO) buffer. You should implement this as a Circular Buffer that satisfies the FIFO property and is restricted to hold at most 1000 items at a time.



(2) Producer: The producer is responsible for producing data items to be added to the buffer. If the buffer is full, the producer must wait for the consumer to consume at least one item before it
can add a new item to the buffer. The producer is required to produce a total of 1,000,000 items.
The item that the producer adds to the buffer is a random Double that is generated using java.util.Random.
Random random = new Random();
Double bufferElement = random.nextDouble() * 100.0;

(3) Consumer: The consumer is responsible for consuming elements from the buffer. If the buffer is empty the consumer must wait for the producer to add an item to the buffer. The consumer is required to consume all elements (1,000,000) generated by the producer.
There should be exactly one instance of the buffer, producer, and consumer. The producer and consumer must reference the same buffer. You can only use wait() and notify() as the primitives to synchronize access to the buffer.
Correctness:
To verify the correctness of your program both the producer and consumer are required to maintain running totals of the values of the items added-to/removed-from the buffer. This would be maintained in a variable bufferValueCounter.
Since the buffer is a FIFO buffer, the value reported for the two items below should be the same:
(a) The first N elements generated by the producer
(b) The first N elements consumed by the consumer



















Requirements of Task

1) Implement the FIFO Circular Buffer and ensure that the buffer can hold a maximum of 1000
items at a time.
2) Consumer should wait if there are no items in the buffer
3) Producer should wait if the buffer is full
4) Ensure that the producer can produce 1,000,000 items and the consumer can consume 1,000,000, items with a bounder buffer that can hold at most 1000 items at a time.
a. You should not run out of memory. Remember, your producer should not produce if the buffer is full. You should not set the size of the Java VM in your makefile or expect that
the JVM will be set to a certain value.
b. Your solution must satisfy the correctness constraint i.e. you consume each item exactly once, in the order that it was produced, and demonstrate this by printing out the value
of your counter (at both the producer and consumer) every time you have produced or consumed 100,000 elements. See the example output below; note how the counter values match at the producer and consumer for the same N.
c. There should be no deadlock. Your program will be executed 5 times, and it should run
to completion every time without a deadlock.

Example:
Print out of what the outputs of the executing programs look like
> java ProducerConsumer
Producer: Generated 100,000 items, Cumulative value of generated items=abc.def
Consumer: Consumed 100,000 items, Cumulative value of consumed items=abc.def
Producer: Generated 200,000 items, Cumulative value of generated items=ghi.jkl
Consumer: Consumed 200,000 items, Cumulative value of consumed items=ghi.jkl
Producer: Generated 300,000 items, Cumulative value of generated items=mno.pqr
Consumer: Consumed 300,000 items, Cumulative value of consumed items=mno.pqr
Producer: Generated 400,000 items, Cumulative value of generated items=stu.vwx
Consumer: Consumed 400,000 items, Cumulative value of consumed items=stu.vwx
Producer: Generated 500,000 items, Cumulative value of generated items=yza.bcd
Consumer: Consumed 500,000 items, Cumulative value of consumed items=yza.bcd
Producer: Generated 600,000 items, Cumulative value of generated items=efg.hij
Consumer: Consumed 600,000 items, Cumulative value of consumed items=efg.hij
Producer: Generated 700,000 items, Cumulative value of generated items=klm.nop
Consumer: Consumed 700,000 items, Cumulative value of consumed items=klm.nop
Producer: Generated 800,000 items, Cumulative value of generated items=qrs.tuv
Consumer: Consumed 800,000 items, Cumulative value of consumed items=qrs.tuv
Producer: Generated 900,000 items, Cumulative value of generated items=wxy.zab
Consumer: Consumed 900,000 items, Cumulative value of consumed items=wxy.zab
Producer: Generated 1,000,000 items, Cumulative value of generated items=cde.fgh
Consumer: Consumed 1,000,000 items, Cumulative value of consumed items=cde.fgh
Producer: Finished generating 1,000,000 items
Consumer: Finished consuming 1,000,000 item
Exiting …


Related Discussions:- multithreading

Mention five applications of artificial intelligent system, Mention any fiv...

Mention any five applications of Artificial Intelligent System? 1)Medical Diagnosis 2)Robots 3) Games 4) Business intelligence 5)Image Recognition.

Produce solutions to modern-practical problems, Students will design, devel...

Students will design, develop, test and document a Java application that reads data from an input file, processes the data, and then writes the processed data to an output file. CM

Write complete application to play game tic-tac-toe, (Tic-Tac-Toe)  Create...

(Tic-Tac-Toe)  Create class TicTacToe that will enable you to write a complete application to play the game of Tic-Tac-Toe. The class contains a private 3-by-3 rectangular array o

Explain exception classes, OOPS with Java 1. Explain any five buzz word...

OOPS with Java 1. Explain any five buzz words in Java. 2. Explain exception classes and also explain common exceptions in java. 3. Explain primitive and abstract data typ

Need tomcat based iptv cms p2p, Need tomcat based iptv cms p2p , avrelay tr...

Need tomcat based iptv cms p2p , avrelay trans-coder software Project Description: Tomcat based iptv cms p2p tracker cdn included, avrelay for trans-coding h264, Skills re

Basic difference b/w finalize(), 1.   final - it is a constant declarati...

1.   final - it is a constant declaration. 2.   finally - handles exception. The finally block is optional and gives a mechanism to clean up regardless of what occurs within

Vending machine, i have got project of Vending machine. would you please he...

i have got project of Vending machine. would you please help me about how to start and how to use coding.thanks

Program a pong game using rmi, Using RMI, program a PONG game that enables ...

Using RMI, program a PONG game that enables two users to play against one another. Pong class: package graphics;/* * Copyright (c) 2006, Your Corporation. All Rights Reserved. */

Explain testing for equality with equals, Explain Testing for Equality with...

Explain Testing for Equality with equals? That's not what you expected. To contrast strings or any other kind of object you required to use the equals(Object o) techniques from

What are the difference between throw and throws, What are the difference b...

What are the difference between throw and throws? Differences are between throws and throw are: Throw is employed to trigger an exception while throws is used in declara

Write Your Message!

Captcha
Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd