Semaphore werden zur Synchronisation von Threads verwendet. Mehr ...
#include <semaphore.h>


Ăffentliche Methoden | |
| Semaphore (int c) | |
| Der Konstruktor initialisiert den SemaphorzÀhler mit dem angegebenen Wert c. Mehr ... | |
| void | p () |
| Warten auf das Freiwerden eines kritischen Abschnitts. Mehr ... | |
| void | v () |
| Freigeben des kritischen Abschnitts. Mehr ... | |
Ăffentliche Methoden geerbt von Waitingroom | |
| virtual | ~Waitingroom () |
| Destruktor. Mehr ... | |
| virtual void | remove (Thread *customer) |
| Mit dieser Methode kann der angegebene Thread customer vorzeitig aus dem Wartezimmer entfernt werden. Mehr ... | |
Ăffentliche Methoden geerbt von Queue< Thread > | |
| Queue () | |
| Der Konstruktor initialisiert die Liste als leere Liste. | |
| void | enqueue (Thread *item) |
| Das Listenelement item wird an das Ende der Liste angefĂŒgt. Mehr ... | |
| Thread * | dequeue () |
| Liefert das erste Element der Liste und entfernt es gleichzeitig aus dieser. Mehr ... | |
| Iterator | begin () |
| Iterator | end () |
| Thread * | remove (Thread *item, bool(*cmp)(Thread *, Thread *)=[](Thread *a, Thread *b) {return a==b;}) |
| Mit dieser Methode kann das angegebene Element item aus der Liste entfernt werden, unabhĂ€ngig von seiner Position dort. Verglichen werden die Pointer-Adressen, optional kann eine Vergleichsfunktion angegeben werden. Die Standardvergleichsfunktion ist ein C++11 Lambda Ausdruck, der auf Pointer-Gleichheit prĂŒft. Mehr ... | |
| void | insert_first (Thread *item) |
| FĂŒgt das item am Anfang der Liste ein. Mehr ... | |
| void | insert_after (Thread *old_item, Thread *new_item) |
| FĂŒgt das Element new_item hinter dem Element old_item in die Liste ein. Mehr ... | |
| Thread * | first () |
| Liefert das erste Element der Liste, ohne es zu entfernen. Mehr ... | |
| Thread * | next (Thread *o) |
| Liefert das nĂ€chste Element der Liste fĂŒr ein gegebenes Element. | |
Weitere Geerbte Elemente | |
Ăffentliche, statische Methoden geerbt von Queue< Thread > | |
| static QueueLink< Thread > * | get_node (Thread *o) |
| Gibt einen Zeiger auf das QueueLink-Element innerhalb des Argument-Objektes zurĂŒck. Mehr ... | |
Semaphore werden zur Synchronisation von Threads verwendet.
Die Klasse Semaphore implementiert das Synchronisationskonzept des zÀhlenden Semaphors. Die benötigte Warteliste erbt sie dabei von ihrer Basisklasse Waitingroom.
|
inline |
Der Konstruktor initialisiert den SemaphorzÀhler mit dem angegebenen Wert c.
| c | Initaler ZĂ€hlerwert des Semaphors |
| void Semaphore::p | ( | ) |
Warten auf das Freiwerden eines kritischen Abschnitts.
Warteoperation: Sofern der SemaphorzĂ€hler gröĂer als Null ist, wird er nur um eins erniedrigt. Anderenfalls wird der aktuell laufende Thread an die Warteliste angefĂŒgt und blockiert.
| void Semaphore::v | ( | ) |
Freigeben des kritischen Abschnitts.
Freigabeoperation: Wenn auf der Warteliste mindestens ein Thread eingetragen ist, wird der erste davon aufgeweckt. Anderenfalls wird der SemaphorzÀhler um eins erhöht.