我开始学习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));
}
}
}
它正确地接受了客户端套接字,正确读取,然后它写入数据并进行新的迭代。在第二次迭代抛出异常。看起来像: 我不知道为什么会这样? 我只需要服务器必须在客户端出现时连续读/写。当客户端消失时,服务器必须接受下一个客户端。
所以主要的问题是:为什么要进行检测以及如何避免它?
...
UPDATE1:我发现在第一次迭代时,两个读/写操作的错误代码都成功。但是(!)在第二次迭代的地方,在那里异常处理错误代码是&#34;文件结束&#34;。但为什么?
答案 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";
}
}