COMP 340 Project 4: Java Consultant Chat Room Simulation
Spring 2011
Due: 5 pm Wednesday June 8 - no late submissions accepted
Worth 40 of your 150 project points

Overview

A Java guru operates an Internet chat room for computer science students ('followers') who wish to discuss the intricacies of Java multithreaded programming. No more than one follower is allowed in the chat room with the guru at any given time. If the chat room is busy, a newly arriving follower will be added to a waiting room of fixed capacity. If the waiting room is full, the follower gives up. Anytime the chat room and waiting room are both empty of followers, the guru takes a nap and must be awakened by the next arriving follower. Your program will simulate the chat room operation using Java threads.

The Cast

Note that each of these will be implemented as a Java class.

Specifications, Details and Requirements

Preliminary: simulation of time
ChatControl
Guru
WaitingRoom
Follower
Execution trace output

Produce output at selected points to demonstrate that the system works properly.

You may need to adjust some of the system parameters to get a nice variety of results.
Coordinating threads
Use the Java monitor facilities to coordinate all thread activities.
Generating random values
Documentation

Reproducible Behavior

Follower interarrival times and service (chat room) times are both based on random values. For program testing purposes, you will want to use the same sequence of random values from one run to the next. To achieve this, you need to know a little about how random number generators work.

Random number generators are more accurately called pseudo-random because they are not truly random. Every time the generator is called to generate a number, it calculates the number by applying a formula to its previously-generated number. So how is the first random number generated? It is based on what we call the seed value. If no seed is provided, the default seed is typically based on the computer's clock value. But if you provide a specific seed value, then you control the number sequence. The same sequence will be produced every time you run the program. This is important when testing multi-threaded software because it provides consistency in an otherwise unpredictable testing scenario!

I recommand this technique. Use java.util.Random objects with fixed seed values. Create one Random object to generate interarrival times and a second one to generate service times. Generate the service requirement at the time each follower object is created, and store this value as a follower instance variable. If you follow these recommendations, all random number generation occurs in the same thread (ChatControl) and both sequences are guaranteed to be reproducible. Be sure to remove the seed for final testing and project submission.

Scoring

The maximum 40 points are broken down as follows:

Provided

In the interest of time, I will provide operational versions of ChatControl.java and Guru.java, plus stub versions of Follower.java and WaitingRoom.java. Right-click on these links to save the files. You are free to make changes to the ChatControl and Guru classes as needed.

To Turn In

Send all Java files as email attachments to psanderson@otterbein.edu.


[ COMP 340 | Peter Sanderson | Math Sciences server | Math Sciences home page | Otterbein ]

Last updated:
Peter Sanderson (PSanderson@otterbein.edu)