0

我试图接收到一个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));
}

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

#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是错的!也许有某种错误的分配?!

4

1 回答 1

0

这是错的那些ffffff是错的!

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

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

另一种选择是转换为unsigned char而不是int输出。

于 2013-09-13T18:03:10.100 回答