ACE
6.3.3
|
This class implements a ``single write, multiple read'' pattern that can be used to return results from asynchronous method invocations. More...
#include <Future.h>
Public Member Functions | |
ACE_Future (void) | |
Constructor. More... | |
ACE_Future (const ACE_Future< T > &r) | |
ACE_Future (const T &r) | |
~ACE_Future (void) | |
Destructor. More... | |
void | operator= (const ACE_Future< T > &r) |
int | cancel (const T &r) |
int | cancel (void) |
bool | operator== (const ACE_Future< T > &r) const |
bool | operator!= (const ACE_Future< T > &r) const |
Inequality operator, which is the opposite of equality. More... | |
int | set (const T &r) |
int | get (T &value, ACE_Time_Value *tv=0) const |
operator T () | |
int | ready (void) const |
Check if the result is available. More... | |
int | attach (ACE_Future_Observer< T > *observer) |
int | detach (ACE_Future_Observer< T > *observer) |
void | dump (void) const |
Dump the state of an object. More... | |
ACE_Future_Rep< T > * | get_rep (void) |
Public Attributes | |
ACE_ALLOC_HOOK_DECLARE | |
Declare the dynamic allocation hooks. More... | |
Private Types | |
typedef ACE_Future_Rep< T > | FUTURE_REP |
Private Attributes | |
FUTURE_REP * | future_rep_ |
This class implements a ``single write, multiple read'' pattern that can be used to return results from asynchronous method invocations.
|
private |
The ACE_Future_Rep Protect operations on the <Future>.
ACE_Future< T >::ACE_Future | ( | void | ) |
Constructor.
ACE_Future< T >::ACE_Future | ( | const ACE_Future< T > & | r | ) |
Copy constructor binds this and r to the same ACE_Future_Rep. An ACE_Future_Rep is created if necessary.
ACE_Future< T >::ACE_Future | ( | const T & | r | ) |
Constructor that initialises an ACE_Future to point to the result r immediately.
ACE_Future< T >::~ACE_Future | ( | void | ) |
Destructor.
int ACE_Future< T >::attach | ( | ACE_Future_Observer< T > * | observer | ) |
Attaches the specified observer to a subject (this ACE_Future). The update method of the specified subject will be invoked with a copy of the associated ACE_Future as input when the result gets set. If the result is already set when this method gets invoked, then the update method of the specified subject will be invoked immediately.
observer | The observer to attach to the subject. |
0 | Success. |
1 | The observer was already attached. |
-1 | Error; check ACE_OS::last_error() for an error code. |
int ACE_Future< T >::cancel | ( | const T & | r | ) |
Cancel an ACE_Future and assign the value r. It is used if a client does not want to wait for the value to be produced.
int ACE_Future< T >::cancel | ( | void | ) |
Cancel an ACE_Future. Put the future into its initial state. Returns 0 on succes and -1 on failure. It is now possible to reuse the ACE_Future. But remember, the ACE_Future is now bound to a new ACE_Future_Rep.
int ACE_Future< T >::detach | ( | ACE_Future_Observer< T > * | observer | ) |
Detaches the specified observer from a subject (this ACE_Future). The update method of the specified subject will not be invoked when the ACE_Future_Rep result gets set.
observer | The observer to attach to the subject. |
0 | The observer was successfully detached. |
-1 | Error, including the observer not attached prior to calling this method. |
void ACE_Future< T >::dump | ( | void | ) | const |
Dump the state of an object.
int ACE_Future< T >::get | ( | T & | value, |
ACE_Time_Value * | tv = 0 |
||
) | const |
Wait to get the object's value.
value | Receives the value of this ACE_Future when it is set. |
tv | Pointer to an ACE_Time_Value containing the absolute time to wait until for the value to be set. If tv is 0, the call waits indefinitely for the value to be set, unless an error occurs. |
0 | Success; value contains the value of the ACE_Future. |
-1 | Error; check ACE_OS::last_error() for an error code. |
ACE_Future_Rep< T > * ACE_Future< T >::get_rep | ( | void | ) |
Get the underlying ACE_Future_Rep pointer. Note that this method should rarely, if ever, be used and that modifying the underlying ACE_Future_Rep should be done with extreme caution.
ACE_Future< T >::operator T | ( | ) |
bool ACE_Future< T >::operator!= | ( | const ACE_Future< T > & | r | ) | const |
Inequality operator, which is the opposite of equality.
void ACE_Future< T >::operator= | ( | const ACE_Future< T > & | r | ) |
Assignment operator that binds this and r to the same ACE_Future_Rep. An ACE_Future_Rep is created if necessary.
bool ACE_Future< T >::operator== | ( | const ACE_Future< T > & | r | ) | const |
Equality operator that returns true
if both ACE_Future objects point to the same ACE_Future_Rep object.
true
if both objects have just been instantiated and not used yet. int ACE_Future< T >::ready | ( | void | ) | const |
Check if the result is available.
int ACE_Future< T >::set | ( | const T & | r | ) |
Make the result available. Is used by the server thread to give the result to all waiting clients. Returns 0 for success, -1 on failure. This function only has an effect the first time it is called for the object (actually, the first time the underlying ACE_Future_Rep has a value assigned to it). Subsequent calls return 0 (success) but have no effect.
ACE_Future< T >::ACE_ALLOC_HOOK_DECLARE |
Declare the dynamic allocation hooks.
|
private |