Boost.Asio翻译(三)--DayTime1 A synchronous TCP daytime client

A synchronous TCP daytime client

一个同步的TCP daytime客户端

说明:

我们需要把服务器的名称转化为TCP的节点,而该名称是通过应用程序的参数指定的。我们使用boost::asio::ip::tcp::resolver 对象来完成。

一个resolver对象获得一个query对象,并将其转换为节点列表.我们通过argv[1]中的服务器名称服务名,在这里是daytime,构造一个query

节点列表用boost::asio::ip::tcp::resolver::iterator类型的迭代器返回。返回的iterator将采用boost::asio::ip::tcp::resolver::iterator的默认构造函数来构造。

现在我们建立一个socket并连接之,由于获得的节点既有IPv4也有IPv6的。所以,我们需要依次尝试访问它们直到找到一个可以正常工作的。这样做可使得我们的程序独立于特定的IP版本。

连接打开后,现在我们需要做的就是读取daytime服务器的响应。

我们使用boost::array来存放接收到的数据。boost::asio::buffer()函数会自动确定array的长度来防止缓冲区溢出。我们也可以使用char[]std::vector来代替boost::array。

当服务器关闭连接时,boost::asio::ip::tcp::socket::read_some()函数boost::asio::error::eof错误标志返回,通过该错误标志,我们知道应该退出循环了



你可能感兴趣的:(client)