18

我正在启动 Boost.Asio 并尝试在官方网站上给出示例。
这是客户端代码:


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

int _tmain(int argc, _TCHAR* argv[])
{
    try {
        boost::asio::io_service io_service;

        tcp::resolver resolver(io_service);
        tcp::resolver::query query(argv[1], "daytime");
        tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
        tcp::resolver::iterator end;

        tcp::socket socket(io_service);
        boost::system::error_code error = boost::asio::error::host_not_found;
        while(error && endpoint_iterator != end) {
            socket.close();
            socket.connect(*endpoint_iterator++, error);
        }
        if (error)
            throw boost::system::system_error(error);

        for(;;) {
            boost::array buf;
            boost::system::error_code error;

            std::size_t len = socket.read_some(boost::asio::buffer(buf), error);

            if (error == boost::asio::error::eof)
                break; //connection closed cleanly by peer
            else if (error)
                throw boost::system::system_error(error);

            std::cout.write(buf.data(), len);
        }
    }
    catch(std::exception& e) {
        //...
    }
    return 0;
}

问题是 - 我无法找出从命令提示符运行程序的参数是什么?

4

4 回答 4

15

您将使用要连接的服务器的 IP 或主机名运行该程序。tcp::resolver::query 将要解析的主机或 IP 作为第一个参数和服务的名称(如在 Unix 主机上的 /etc/services 中定义的那样) - 您还可以使用数字服务标识符(又名端口数字)。它返回一个可能的端点列表,因为单个主机可能有多个条目。

于 2009-02-15T17:48:12.930 回答
8

阅读旧手册!

ip::tcp::resolver resolver(my_io_service);
ip::tcp::resolver::query query("www.boost.org", "http");
ip::tcp::resolver::iterator iter = resolver.resolve(query);
ip::tcp::resolver::iterator end; // End marker.
while (iter != end)
{
    ip::tcp::endpoint endpoint = *iter++;
    std::cout << endpoint << std::endl;
}

http://www.boost.org/doc/libs/1_38_0/doc/html/boost_asio/overview/networking/protocols.html

于 2013-04-02T10:48:12.593 回答
4

我现在遇到了同样的问题(使用相同的教程)。将服务器代码更改为:

tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4(), 19876));

并更改客户端代码:

tcp::resolver::query query(argv[1], "19876");

使相同的服务在不同的端口上工作。

于 2012-12-17T18:02:12.523 回答
0

如果我没记错的话,你正在尝试使用 UNICODE 字符串——tchar。使用标准

int main(int argc,char **argv)
于 2009-02-15T17:39:45.557 回答