dnfpk001 发表于 2017-7-12 15:23:00

《C++Boost库asio》第九篇

Echo服务器对应的C++客户端 :
(对照上一篇来学习,接收和发送的顺序是一样的)


// Echo服务器对应的C++客户端 :
// 同步的,阻塞式的客户端
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <boost\asio.hpp>
#include <boost\array.hpp>

//不用UDP协议的原因是包的大小有限制,然后有可能是乱序,
// 重发,丢包都有可能,有TCP还是比较简单安全的

using boost::asio::ip::tcp;

enum { max_length = 1024 };

int main()
{
        boost::asio::io_service io_service;

        tcp::socket s(io_service);
        tcp::endpoint ep(boost::asio::ip::address::from_string("127.0.0.1"), 2001);
        s.connect(ep);

        //在这里,3次握手成功

        size_t request_length = 1024;
        char reply;
        size_t reply_length;
        // --接收服务器发来的当前时间 ;       


        boost::array<char, 128> buf;//字节流缓存
        boost::system::error_code error;//错误码的形式来返回错误,而不是用抛出异常的方式
        size_t len = s.read_some(boost::asio::buffer(buf), error);//开始读取服务器发来的数据
        if (error == boost::asio::error::eof)
        {
                return 0;// 服务器关闭了连接,客户端可以直接退出了
        }
        else if (error)
        {
                throw boost::system::system_error(error);//一些其他的错误
        }
        std::cout << "Reply is :";
        std::cout.write(buf.data(), len);//输出到控制台


        // --发消息给服务器 ;
        std::cout << "Enter message:";
        char request;
        std::cin.getline(request, max_length);//输入
        request_length = std::strlen(request);
        boost::asio::write(s, boost::asio::buffer(request, request_length)); // 出错会抛出异常;

        // --接收服务器发来的消息 ;
        //错了会抛异常,真正收到request_length多长度的数据后才会往下走,否则一直等待
        reply_length = boost::asio::read(s, boost::asio::buffer(reply,request_length));
        std::cout << "Reply is :";
        std::cout.write(reply, reply_length);//输出到控制台


        getchar();
        system("pause");
    return 0;
}
页: [1]
查看完整版本: 《C++Boost库asio》第九篇