繁体   English   中英

boost async_read_some读取错误的缓冲区

[英]boost async_read_some reads wrong buffer

正在尝试接收queue->buffer ,其中queue->bufferchar * buffer = new char[1024]

void AsyncConnection::BeginReceive(){

    m_socket.async_read_some(boost::asio::buffer(&queue->GetBuffer()[queue->GetOffset()], queue->GetBufferLength() - queue->GetOffset()), boost::bind(&AsyncConnection::EndReceive, shared_from_this(),
        boost::asio::placeholders::error,
        boost::asio::placeholders::bytes_transferred));
}

并使用此方法将bytes数组转换为十六进制:

#include <iomanip>
void output_hex(std::ostream& out, char* buf, int len) {
    for (int i = 0; i < len; i++)
        out << std::noshowbase
        << std::hex
        << std::setfill('0')
        << std::setw(2)
        << static_cast<int> (buf[i])
        << " ";
    out << std::dec << std::endl;
}

输出看起来像这样:-

17 ffffff84 04 65 ffffff83 45 fffffff3 ffffffe2 ffffffdf 0f 33 ffffffa5 14 fffff
fcb 75 6f 5f ffffff89 ffffffb0 22 27 fffffffe ffffffeb fffffff2 ffffffef ffffffe
8 53 40 ffffffbe 18 ffffffa6 ffffff84 67 53 33 ffffffd6 ffffffa6 16 ffffff81 fff
fffe0 ffffffd9 05 35 ffffffab 16 ffffffc1 7f 6d 59 ffffff87 ffffffba 20

那些ffffff错了! 也许分配不好?!

那些ffffff错了!

这是因为在您的平台上, char是带符号的,因此字节值被视为带符号的类型。 设置了最高位的任何值(例如第二个值84 )都将被视为负值,并且向int的转换会将所有新位设置为1以保留负值。 这就是ffffff

一种选择是在处理二进制数据的任何地方都使用unsigned char而不是char

另一种选择是将其转换为unsigned char而不是int以进行输出。

暂无
暂无

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

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