boost asio 性能与线程安全性

http://stackoverflow.com/questions/12794107/why-do-i-need-strand-per-connection-when-using-boostasio/12801042

http://www.boost.org/doc/libs/1_51_0/doc/html/boost_asio/overview/core/strands.html

url1:  同一个socket上, 不能 read write读写不能并发。。。。 !!!!???? 这个感觉不可能吧。。。那也太弱智了。。

====确实不能对同一个socket同时读写,socket能封装了basic_socket_stream, 该类的对象不能支持同时进行读写操作。ps, fstream也不能支持同时读写吧。。



http://stackoverflow.com/questions/4078484/using-boost-sockets-do-i-need-only-one-io-service

只强调, 不能 对同一个socket同时多读, 或者同时多写。



http://stackoverflow.com/questions/6161725/boostasio-threadpool-vs-io-service-per-cpu-design

性能递升。。。

  1. single thread and a single io_service
  2. multiple threads, each invoking io_service::run() from a single io_service. Use strands for handlers that require access to shared data structures.
  3. io_service per cpu

http://en.highscore.de/cpp/boost/asio.html#asio_networkprogramming

high score boost里面有boost asio的用法

1) single thread && single io_service, 最简单, 性能最一般

2) multithread && single io_service

3) io_service per thread.  multi io_service.

这三个性能应该也是递增的。。。



http://stackoverflow.com/questions/11010530/do-we-need-multiple-io-service-per-thread-for-threaded-boostasio-server-with/11011080#11011080

single thread && single io_service性能肯定是不够的。

boost asio example

HTTP Server 2

An HTTP server using an io_service-per-CPU design.

HTTP Server 3

An HTTP server using a single io_service and a thread pool calling io_service::run().



http://stackoverflow.com/questions/8557067/thread-safe-coroutines-with-asio
http://www.crystalclearsoftware.com/soc/coroutine/coroutine/coroutine_thread.html
coroutine能使异步切碎的逻辑看起来像同步的方式写代码。
但是coroutine不能支持多线程, 只能一个ioservice一个线程的方式。



  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Boost.Asio是一个跨平台网络编程库,可以用于开发高性能的网络应用程序。 Boost.Asio中提供了多种IO服务类型,包括同步IO服务、异步IO服务、定时器服务等。其中,异步IO服务是最常用的,因为它可以提高程序的并发和吞吐量。 异步IO服务需要使用回调函数来处理IO事件。在高并发的网络应用程序中,如果每个IO事件都启动一个线程来处理,会导致系统资源的浪费和线程调度的开销。为了解决这个问题,可以使用线程池来管理线程。 Boost.Asio提供了io_service::strand类,可以用于将多个异步IO操作序列化,使得它们在同一个线程中执行。通过将io_service::strand对象与线程池结合使用,可以实现线程池的功能。 下面是一个使用Boost.Asio实现线程池的示例代码: ```cpp #include <boost/asio.hpp> #include <boost/thread.hpp> #include <iostream> class ThreadPool { public: explicit ThreadPool(std::size_t size) : work_(io_service_), size_(size) { for (std::size_t i = 0; i < size_; ++i) { threads_.create_thread(boost::bind(&boost::asio::io_service::run, &io_service_)); } } ~ThreadPool() { io_service_.stop(); threads_.join_all(); } template<typename F> void post(F f) { io_service_.post(f); } private: boost::asio::io_service io_service_; boost::asio::io_service::work work_; boost::thread_group threads_; std::size_t size_; }; int main() { ThreadPool pool(4); for (int i = 0; i < 10; ++i) { pool.post([i]() { std::cout << "Task " << i << " is running on thread " << boost::this_thread::get_id() << std::endl; }); } return 0; } ``` 在上面的代码中,ThreadPool类封装了一个io_service对象和一个线程池。构造函数中创建了多个线程,并通过io_service::run函数启动线程。post函数用于向线程池中提交任务,任务会被异步执行。在主函数中,向线程池中提交了10个任务,每个任务输出当前线程的ID和任务的编号。 需要注意的是,io_service类并不是线程安全的。因此,在多个线程中使用同一个io_service对象时,需要使用io_service::strand类来保证异步IO操作的顺序。在上面的示例代码中,由于每个线程都会从io_service对象中取出任务并执行,因此不需要使用io_service::strand类。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值