ASIO(1.4.3) Tutorial : Timer.2 - Using a timer asynchronously
//
// timer.cpp
// ~~~~~~~~~
//
// Copyright (c) 2003-2008 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
#include <iostream>
#include <boost/asio.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
void print(const boost::system::error_code& /*e*/)
{
std::cout << "Hello, world!\n";
}
int main()
{
boost::asio::io_service io;
boost::asio::deadline_timer t(io, boost::posix_time::seconds(5));
t.async_wait(print);
io.run();
return 0;
}
1. io_service初始化:
new一个新的boost::asio::detail::service_registry对象,赋值service_registry_;
向service_registry_注册平台相关的detail::task_io_service<detail::epoll_reactor<false> >服务对象,
该服务对象包括使用的事件分发器(epoll_reactor),事件分发器会在task_io_service的init_task方法中进行注册;
返回服务对象的引用赋值impl_。
2. deadline_timer(io_object)初始化:
typedef basic_deadline_timer<boost::posix_time::ptime> deadline_timer;
deadline_timer是basic_deadline_timer的一个实例类,basic_deadline_timer继承于basic_io_object;
basic_io_object构造时new一个新的为该io_object提供对应服务的service对象(deadline_timer_service<Time, TimeTraits>)并向service_registry_注册;
deadline_timer_service构造时向service_registry_注册平台相关的detail::deadline_timer_service<traits_type, detail::epoll_reactor<false> >服务对象,返回服务对象的引用赋值service_impl_;
detail::deadline_timer_service构造时向service_registry_注册detail::epool_reactor<false>事件分发器服务对象,返回事件分发器对象的引用赋值scheduler_;
然后调用detail::epool_reactor的init_task和add_timer_queue方法;
detail::epool_reactor的init_task方法中,如果reactor不是独立的线程,则注册detail::task_io_service<epoll_reactor<Own_Thread> >服务并调用init_task使用epoll_reactor<Own_Thread>服务对task_进行初始化;
detail::epool_reactor的add_timer_queue方法,将一个新的定时器队列添加到事件分发器。
所有io_object都继承自basic_io_object,其中包括为该io对象进行服务的IoObjectService以及该io对象的声明IoObjectService::implementation_type;
所有io_object对象初始化时,将服务对象作为basic_io_object类参数传入basic_io_object中并在其构造函数中使用use_service对该服务对象进行注册并调用服务对象的construct方法对implementation_type进行初始化;
所有io_object对象销毁时,在basic_io_object析构函数中调用与io_object相对应服务对象的destroy对implementation_type进行销毁;
所有io_object对象的类模板都以basic开头,具体的io_object对象则是类模板产生的一个实例类;
所有io_object对象都能获得对应的用来处理分发处理器以及异步操作的io_object对象;
客户端向io_object发起请求,io_object先将处理请求发送给平台无关的服务对象,再由平台无关的服务对象将请求转发给平台相关的服务对象,完成最终的请求。
3. 调用async_wait(handler):
调用deadline_timer的async_wait(...)方法,传入回调函数,回调函数的类型为 void handler(const boost::system::error_code&),也可以通过bind方法添加额外的参数;
async_wait(...)方法调用相关平台无关服务(deadline_timer_service)的async_wait,传入io对象声明以及回调函数;
平台无关服务的async_wait(...)再调用平台相关的服务(detail::deadline_timer_service)的async_wait,传入io对象声明以及回调函数;
平台相关服务的async_wait(...)调用反应器(detail::epool_reactor<false>)的schedule_timer方法对该定时器进行计划,通过wait_handler函数类对原始的handler进行封装;
schedule_timer方法调用enqueue_timer(...)方法将定时器以及回调方法加入到timer_queue(detail::deadline_timer_service的实例变量且detail::epool_reactor<false>保存其引用);
enqueue_timer方法构造新的timer。