繁体   English   中英

Boost::Asio::Read 未填充缓冲区

[英]Boost::Asio::Read is not populating buffer

这是我的服务器类,它在连接时呈现异步事件以将字符串发送到我的客户端。

消息肯定会发送到客户端,因为 writehandler 被成功调用,没有任何错误:

class Server {
private:

    void writeHandler(ServerConnection connection, const boost::system::error_code &error_code,
                      std::size_t bytes_transferred) {

        if (!(error_code)) {
            std::cout << "SENT "<<bytes_transferred <<" BYTES"<< std::endl;
        }
    }

    void renderWriteEvent(ServerConnection connection, const std::string& str) {
        std::cout << "RENDERING WRITE EVENT" << std::endl;
        connection->write = str;
        boost::asio::async_write(connection->socket, boost::asio::buffer(connection->write),
                                 boost::bind(&Server::writeHandler, this, connection,
                                             boost::asio::placeholders::error,
                                             boost::asio::placeholders::bytes_transferred));
    }
    

};

现在在客户端,成功连接到服务器后,我调用

        void renderRead(){
        std::cout<<"Available Bytes: "<<socket.available()<<std::endl;
        std::string foo;


        boost::system::error_code error_code;
        std::size_t x = socket.read_some(boost::asio::buffer(foo), error_code);
        std::cout<<error_code.message()<<std::endl;

        std::cout<<"Bytes read: "<<x<<std::endl;
        std::cout<<"Available Bytes: "<<socket.available()<<std::endl;
        std::cout<<foo<<std::endl;
        //boost::asio::async_read(socket, boost::asio::buffer(read_string), boost::bind(&Client::readHandler, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
    }

输出“可用字节:12”

然后,在调用boost::asio::read ,我读取了 0 个字节,并且没有错误。 我不明白出了什么问题。 读取后,socket流中可供读取的字节数仍然打印为12

这里的一个关键点是read_some()不分配任何内存,它填充提供给它的内存。 对于您的代码,这意味着 ASIO 只会替换foo已经存在的数据,并且永远不会超出这些范围。

但是你有std::string foo; ,这是一个默认构造的字符串,也就是一个字符串。

所以 ASIO 正在填充你传递的缓冲区就好了。 但是,您传递给它的是一个没有空间的缓冲区。 ASIO 尽可能地填充它:0 字节。

您可以通过将以下内容添加到您的代码中来自行测试:

std::string foo;
std::cout << "Available room in buffer: "<< foo.size() << std::endl;

解决方法是传递一个已分配内存的缓冲区。 可以使用长度初始化字符串,但使用稍后将其解释为string_view的原始字节块更为明确。

constexpr std::size_t buffer_size = 32;

std::array<char, buffer_size> foo;
std::size_t x = socket.read_some(boost::asio::buffer(foo), error_code);

//...

std::string_view message(foo.data(), x);
std::cout << message << std::endl;


暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM