StuBS
GuardedSemaphore Class Reference

Guarded interface to Semaphore objects used by user applications. More...

#include <guarded_semaphore.h>

Inheritance diagram for GuardedSemaphore:
Collaboration diagram for GuardedSemaphore:

Public Member Functions

 GuardedSemaphore (int c)
 The constructor passes the parameters to the base-class constructor. More...
 
void p ()
 Wait for access to the critical area. More...
 
void v ()
 Leave the critical area. More...
 
- Public Member Functions inherited from Semaphore
 Semaphore (unsigned c=0)
 Constructor; initialized the counter with provided value c More...
 
void p ()
 Wait for access to the critical area. More...
 
void v ()
 Leave the critical area. More...
 
- Public Member Functions inherited from Waitingroom
 Waitingroom ()
 Constructor. More...
 
virtual ~Waitingroom ()
 Destructor. More...
 
virtual void remove (Thread *customer)
 Remove a given thread prematurely from the Waitingroom. More...
 

Detailed Description

Guarded interface to Semaphore objects used by user applications.

Implements the system call interface for class Semaphore. All methods provided by this class are wrappers for the respective method from the base class, which provide additional synchronization by using the class Guarded.

Constructor & Destructor Documentation

◆ GuardedSemaphore()

GuardedSemaphore::GuardedSemaphore ( int  c)
inlineexplicit

The constructor passes the parameters to the base-class constructor.

Member Function Documentation

◆ p()

void GuardedSemaphore::p ( )
inline

Wait for access to the critical area.

Enter/Wait operation: If the counter is greater than 0, then it is decremented by one. Otherwise the calling thread will be enqueued into the Waitingroom and marked as blocked.

Note
This method is equal to the correspondent method in base class Semaphore, with the only difference that the call will be protected by a Guarded object.

◆ v()

void GuardedSemaphore::v ( )
inline

Leave the critical area.

Leave operation: If there are threads in the Waitingroom, wake the first one; otherwise increment the counter by one.

Note
This method is equal to the correspondent method in base class Semaphore, with the only difference that the call will be protected by a Guarded object.

The documentation for this class was generated from the following file: