在上篇博文中,我们学习了boost::asio库的同步I/O机制,里面的代码比较的简单,但是也是很重要,在这篇博文中,我们继续学习boost::asio库的异步方式,异步方式与同步方式的最大的不同,想必大家都很清楚,简单地来讲就是一个需要等待,一个不会等待,至于两者之间一些细节的不同,大家就放狗搜吧,好了,下面来看代码,代码如下:
服务器端代码
#ifndef __ASERVER__H
#define __ASERVER__H
#include <iostream>
#include <string>
#include <unistd.h>
#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <boost/smart_ptr.hpp>
using namespace boost::asio;
using boost::system::error_code;
using ip::tcp;
class CService
{
public:
CService(io_service& io_serv):m_ioserv(io_serv),m_acceptor(io_serv,tcp::endpoint(tcp::v4(),9999)){}
~CService(){}
void start()
{
boost::shared_ptr<tcp::socket> pSocket(new tcp::socket(m_ioserv));
m_acceptor.async_accept(*pSocket,boost::bind(&CService::accept_handler,this,pSocket,_1));
}
void accept_handler(boost::shared_ptr<tcp::socket> pSocket,error_code ecode)
{
if(ecode) return;
start();
pid_t forkid;
std::cout<<pSocket->remote_endpoint().address()<<std::endl;
forkid = fork();
if(forkid ==0)
{
for(;;)
{
#define MAX_BUFFERSIZE 1024
char buff[MAX_BUFFERSIZE];
bzero(buff,sizeof(buff));
pSocket->async_read_some(buffer(buff),boost::bind(&CService::read_handler,this,buff,_1,_2));
boost::share