boost :: asio读/写麻烦

时间:2015-02-12 20:30:53

标签: c++ boost boost-asio

我开始学习boost :: asio并尝试制作简单的客户端 - 服务器应用程序。现在我遇到了服务器问题。在这里代码:

int main(int argc, char* argv[])
{
    using namespace boost::asio;

    io_service service;
    ip::tcp::endpoint endp(ip::tcp::v4(), 2001);
    ip::tcp::acceptor acc(service, endp);

    for (;;)
    {
        socker_ptr sock(new ip::tcp::socket(service));
        acc.accept(*sock);
        for (;;)
        {
            byte data[512];

            size_t len = sock->read_some(buffer(data));  // <--- here exception at second iteration

            if (len > 0)
                write(*sock, buffer("ok", 2));
        }
    }
}

它正确地接受了客户端套接字,正确读取,然后它写入数据并进行新的迭代。在第二次迭代抛出异常。看起来像: enter image description here  我不知道为什么会这样? 我只需要服务器必须在客户端出现时连续读/写。当客户端消失时,服务器必须接受下一个客户端。

所以主要的问题是:为什么要进行检测以及如何避免它?

...

UPDATE1:我发现在第一次迭代时,两个读/写操作的错误代码都成功。但是(!)在第二次迭代的地方,在那里异常处理错误代码是&#34;文件结束&#34;。但为什么?

1 个答案:

答案 0 :(得分:1)

您收到文件结束条件,因为连接的远程端已关闭或断开连接。

您应该处理系统错误,或使用引用boost::system::error_code的重载。你怎么能终止无限循环?

<强> Live On Coliru

#include <boost/asio.hpp>
#include <iostream>

int main()
{
    using namespace boost::asio;

    io_service service;
    ip::tcp::endpoint endp(ip::tcp::v4(), 2001);
    ip::tcp::acceptor acc(service, endp);

    for (;;)
    {
        ip::tcp::socket sock(service);
        acc.accept(sock);
        boost::system::error_code ec;

        while (!ec)
        {
            uint8_t data[512];

            size_t len = sock.read_some(buffer(data), ec);

            if (len > 0)
            {
                std::cout << "received " << len << " bytes\n";
                write(sock, buffer("ok", 2));
            }
        }

        std::cout << "Closed: " << ec.message() << "\n";
    }
}