开源项目(库)之boost::asio学习(二)

在上篇关于boost::asio的博客中,我们探讨了同步I/O。本文将继续探讨异步I/O,其主要特点是不需要等待。通过简化后的服务器和客户端代码示例,我们展示了如何使用boost::asio的异步接口。通过实践和理解这些案例,我们可以逐步掌握boost::asio的使用,并思考其设计原理。更多深入理解可能需要查看源码,但目前的重点是熟练运用boost::asio。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在上篇博文中,我们学习了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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值