|  | Home | Libraries | People | FAQ | More | 
Provides serialised handler execution.
class strand
| Name | Description | 
|---|---|
| Request the strand to invoke the given handler. | |
| Get the io_service associated with the strand. | |
| (Deprecated: use get_io_service().) Get the io_service associated with the strand. | |
| Request the strand to invoke the given handler and return immediately. | |
| Constructor. | |
| Create a new handler that automatically dispatches the wrapped handler on the strand. | |
| Destructor. | 
        The io_service::strand class provides the ability
        to post and dispatch handlers with the guarantee that none of those handlers
        will execute concurrently.
      
Given:
if any of the following conditions are true:
        then asio_handler_invoke(a1,
        &a1) happens-before asio_handler_invoke(b1,
        &b1).
      
Note that in the following case:
async_op_1(..., s.wrap(a)); async_op_2(..., s.wrap(b));
        the completion of the first async operation will perform s.dispatch(a),
        and the second will perform s.dispatch(b),
        but the order in which those are performed is unspecified. That is, you cannot
        state whether one happens-before the other. Therefore none of the above conditions
        are met and no ordering guarantee is made.
      
Distinct objects: Safe.
Shared objects: Safe.
        Header: boost/asio/strand.hpp
      
        Convenience header: boost/asio.hpp