<< Chapter < Page Chapter >> Page >

Monitors

Monitors are a high-level data abstraction tool combining three features:

  • Shared data.
  • Operations on the data.
  • Synchronization, scheduling.

They are especially convenient for synchronization involving lots of state.

Existing implementations of monitors are embedded in programming languages. Best existing implementations are the Java programminglanguage from Sun and the Mesa language from Xerox.

There is one binary semaphore associated with each monitor, mutual exclusion is implicit: P on entry to any routine, V on exit.This synchronization is automatically done by the compiler (because he makes automatic calls to the OS), and the programmer does not seem them. They come forfree when the programmer declares a module to be a monitor.

Monitors are a higher-level concept than P and V. They are easier and safer to use, but less flexible, at least in raw form asabove.

Probably the best implementation is in the Mesa language, which extends the simple model above with several additions toincrease the flexibility and efficiency.

Do an example: implement a producer/consumer pair.

The "classic" Hoare-style monitor (using C++ style syntax):

class QueueHandler { private:static int BUFFSIZE = 200; int first;int last; int buff[BUFFSIZE]; condition full;condition empty; int ModIncr(int v) {return (v+1)%BUFFSIZE; }public: void QueueHandler (int);void AddToQueue (int); int RemoveFromQueue ();}; voidQueueHandler::QueueHandler (int val) {first = last = 0; }void QueueHandler::AddToQueue (int val) {{ while (ModIncr(last) == first) {full.wait(); }buff[last] = val;last = ModIncr(last); empty.notify();} intQueueHandler::RemoveFromQueue (); {while (first == last) { empty.wait();} int ret = buff[first]; first = ModIncr(first);full.notify(); return ret;}

Java only allows one condition variable (implicit) per object. Here is the same solution in Java:

class QueueHandler { final static int BUFFSIZE = 200;private int first; private int last;private int buff[BUFFSIZE];private int ModIncr(int v) { return (v+1)%BUFFSIZE;} public QueueHandler (int val){ first = last = 0;} public synchronized void AddToQueue (int val) {{ while (ModIncr(last) == first) {try { wait(); } catch (InterruptedException e) {}} buff[last]= val; last = ModIncr(last);notify(); }public synchronized int RemoveFromQueue (); {while (first == last) { try { wait(); }catch (InterruptedException e) {} }int ret = buff[first];first = ModIncr(first); notify();return ret; }

Condition variables: things to wait on. Two types: (1) classic Hoare/Mesa condition variables and (2) Java condition variables.

Hoare/Mesa condition variables:

  • condition.wait(): release monitor lock, put process to sleep. When process wakes up again, re-acquire monitor lock immediately.
  • condition.notify(): wake up one process waiting on the condition variable (FIFO). If nobody waiting, do nothing.
  • condition.broadcast(): wake up all processes waiting on the condition variable. If nobody waiting, do nothing.

Questions & Answers

what are components of cells
ofosola Reply
twugzfisfjxxkvdsifgfuy7 it
Sami
58214993
Sami
what is a salt
John
the difference between male and female reproduction
John
what is computed
IBRAHIM Reply
what is biology
IBRAHIM
what is the full meaning of biology
IBRAHIM
what is biology
Jeneba
what is cell
Kuot
425844168
Sami
what is biology
Inenevwo
what is cytoplasm
Emmanuel Reply
structure of an animal cell
Arrey Reply
what happens when the eustachian tube is blocked
Puseletso Reply
what's atoms
Achol Reply
discuss how the following factors such as predation risk, competition and habitat structure influence animal's foraging behavior in essay form
Burnet Reply
cell?
Kuot
location of cervical vertebra
KENNEDY Reply
What are acid
Sheriff Reply
define biology infour way
Happiness Reply
What are types of cell
Nansoh Reply
how can I get this book
Gatyin Reply
what is lump
Chineye Reply
what is cell
Maluak Reply
what is biology
Maluak
what is vertibrate
Jeneba
what's cornea?
Majak Reply
what are cell
Achol
Got questions? Join the online conversation and get instant answers!
Jobilize.com Reply

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Operating systems. OpenStax CNX. Aug 13, 2009 Download for free at http://cnx.org/content/col10785/1.2
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Operating systems' conversation and receive update notifications?

Ask