diff options
author | nanbor <nanbor@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1998-07-29 09:20:56 +0000 |
---|---|---|
committer | nanbor <nanbor@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1998-07-29 09:20:56 +0000 |
commit | 6df1b16949cf0158e6e6e7ae846095bba70acff2 (patch) | |
tree | 9bbf420eba5ebd51063db7e18449b69d08b00f45 /ace/Token.h | |
parent | 1a41cb2ffa2527525fba95d467f4d8c100555fad (diff) | |
download | ATCD-6df1b16949cf0158e6e6e7ae846095bba70acff2.tar.gz |
*** empty log message ***
Diffstat (limited to 'ace/Token.h')
-rw-r--r-- | ace/Token.h | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/ace/Token.h b/ace/Token.h index 310d928e2cf..150788669b6 100644 --- a/ace/Token.h +++ b/ace/Token.h @@ -41,6 +41,17 @@ class ACE_Export ACE_Token // blocked awaiting the token are serviced in strict FIFO order as // other threads release the token (Solaris and Pthread mutexes don't // strictly enforce an acquisition order). + // There are two FIFO lists within the class. Write acquires always + // have higher priority over read acquires. Which means, if you use + // both write/read operations, care must be taken to avoid starvation + // on the readers. Notice that the read/write acquire operations + // do not have the usual semantic of reader/writer locks. Only one + // reader can acquire the token at a time (which is different from + // the usual reader/writer locks where several readers can acquire + // a lock at the same time as long as there is no writer waiting for + // the lock.) We choose the names 1.) to borrow the semantic to give + // writers higher priority, and, 2.) to support a common interface + // over all locking classes in ACE. public: // = Initialization and termination. @@ -90,6 +101,7 @@ public: // nesting_level_ > 1. I'm not sure if this is really the right // thing to do (since it makes it possible for shared data to be // changed unexpectedly) so use with caution... + // This method maintians the original token priority. int tryacquire (void); // Become interface-compliant with other lock mechanisms (implements @@ -103,7 +115,8 @@ public: // in line gets it. int acquire_read (void); - // Just calls <acquire>. + // Behave like acquire but in a lower priority. It should probably + // be called acquire_yield. int acquire_read (void (*sleep_hook)(void *), void *arg = 0, @@ -119,7 +132,7 @@ public: // More sophisticate version of acquire_write. int tryacquire_read (void); - // Just calls <tryacquire>. + // Lower priority try_acquire. int tryacquire_write (void); // Just calls <tryacquire>. |