开发者

boost::asio socket async_* strand

开发者 https://www.devze.com 2023-03-24 06:50 出处:网络
How to perform async_* operations on socket through the strand? I\'ve looked at Timer.5 (Boost/Asio examples), but they only show how to invoke user\'s handler. When I async_write to the socket in mul

How to perform async_* operations on socket through the strand? I've looked at Timer.5 (Boost/Asio examples), but they only show how to invoke user's handler. When I async_write to the socket in multithreaded application data may be writ开发者_开发技巧ten corrupted. And a strand guarantees that none of those handlers will execute concurrently.


From Boost.Asio docs:

The io_service::strand class provides the ability to post and dispatch handlers with the guarantee that none of those handlers will execute concurrently.

There's a good example of strand usage in Boost.Asio examples.

strand guarantees that your handler execution will be synchronized. That means that strand is useful if your io_service is executed from multiple threads. It's not related to how you schedule your tasks (handlers).

strand cannot help you to do multiple socket read or write ops concurrently, because internal read/write execution cannot be done concurrently, so there should be just one active read or write async op.

For reads you just call async_read to initiate read sequence and call it again from your read handler after consuming received data. The same that you do in single threaded environment.

For writes if there're concurrent producers (if multiple threads provides data to be written to socket) you need a concurrent queue (e.g. boost circular buffer, look for "Bounded Buffer Example"). Your write function takes data from this buffer and async writes it to socket. Your write handler invokes your write function.


When I async_write() to the socket in multithreaded application data may be written corrupted. And Strand guarantee that none of those handlers will execute concurrently.

If multiple threads need to write data on the socket, you will have to ensure ordering of the data. This is explicitly clear in the async_write() documentation.

The program must ensure that the stream performs no other write operations (such as async_write, the stream's async_write_some function, or any other composed operations that perform writes) until this operation completes.

I suggest maintain an outgoing queue of messages, which is very similar to this question and my answer.

0

精彩评论

暂无评论...
验证码 换一张
取 消