Posted on 2009-03-05 15:17
kongkongzi 阅读(708)
评论(0) 编辑 收藏 引用 所属分类:
c++ network library
boost::asio
boost::asio::io_service // This class provides access to I/O functionality.
boost::asio::io_service::run(); // Run the io_service's event processing loop.
// 在run之前已经注册了(将)要处理的Event
boost::asio::io_service::post(CompletionHandler handler); // Request the io_service to
// invoke the given handler and return immediately.
boost::asio::ip::tcp::acceptor
boost::asio::strand // guarantees that, for those handlers that are dispatched through it,
// an executing handler will be allowed to complete before the next one is started.
boost::bind // bind any argument to a specific value or route input arguments into arbitrary positions
strand_.wrap(boost::bind(&tcp_client_jade::handle_read_type, shared_from_this(),
boost::asio::placeholders::error));
strand_.wrap(boost::bind(&tcp_client_jade::handle_read_type, shared_from_this(),
boost::asio::placeholders::error));
strand_.wrap(boost::bind(&session::handle_write, shared_from_this(),
boost::asio::placeholders::error));
使用io_service作为处理工作的work pool,可以看到,就是通过io_service.post投递一个Handler到io_service的队列,Handler在这个io_service.run内部得到执行,有可能你会发现,io_services.dispatch的接口也和io_service.post一样,但不同的是它是直接调用而不是经过push到队列然后在io_services.run中执行,而在这个示例当中,显然我们需要把工作交到另一个线程去完成,这样才不会影响网络接收线程池的工作以达到高效率的接收数据,这种设计与前面的netsever其实相同,这就是典型的Half Sync/Half Async。二者的区别就是netsever自己实现了工作队列,而不是直接使用io_service,这种设计实际上在win下是使用了iocp作为工作队列。
不过我更倾向于前一种设计,因为那样做,代码一切都在自己的掌握中,而io_service则是经过许多封装代码,并且本身设计只是用于处理网络完成事件的。
无论如何使用,都能感觉到使用boost.asio实现服务器,不尽是一件非常轻松的事,而且代码很漂亮,逻辑也相当清晰,这点上很不同于ACE。
我觉IO_SERVICE是一个基本性的接口,基本上通常用到的类实例都需要通过它来构造功能我们可以看似socket
学习boost的使用:
1、查看源代码。boost在源码了添加了大量的注释,对于理解某个函数的功能、使用方法等都有大量的说明。
2、查看doc文档。boost在doc里提供了比较多的应用实例,可以参考。
/// The type of the service that will be used to provide I/O operations.
typedef IoObjectService service_type;
/// The underlying implementation type of I/O object.
typedef typename service_type::implementation_type implementation_type;
// The backend service implementation.
service_type& service;
// The underlying native implementation.
implementation_type implementation;
数据与操作的分离?
io_service associated with the object.
boost::asio::detail::task_io_service<boost::asio::detail::epoll_reactor<false> >::do_one
boost/asio/detail/task_io_service.hpp:222