io_service相當于注冊異步回調的一個上下文環境,而run相當于處理異步io的上下文(通常是一個線程)。
單io_service,多線程run,相當于多個線程同時來處理注冊在一個io_service上的回調:
//sio_mth.cpp
#include <boost/asio.hpp>
#include <boost/date_time/posix_time/posix_time_types.hpp>
#include <iostream>
#include <chrono>
#include <thread>
#include <functional>
using namespace boost::asio;
using namespace std;thread_local int t_id = 0;
unsigned long getTimestamp()
{return std::chrono::system_clock::now().time_since_epoch().count()/std::chrono::system_clock::period::den;
}void timer_handler(int timerID, const boost::system::error_code& err)
{if (err){cout << getTimestamp() << " Timer cancel" << endl;return;}cout << getTimestamp() <<" t_id:" << t_id << " timerID:" << timerID << " " << " Time