问题
我有一些字节缓冲区,它在运行时被填充。我想使用十六进制代码显示缓冲区的内容。所以这是缓冲区的定义:
enum { max_data_length = 8192 }; //8KB
unsigned char stream_data_[max_data_length];
现在我想打印内容。数据存储如下:
stream_data_[0] = 124;
stream_data_[1] = 198;
stream_data_[2] = 60;
现在我要打印此缓冲区的内容(十六进制)。我尝试了几个堆栈溢出帖子,但它们都使用unsigned int或填充数组。我真的被这个问题困住了!
代码
我试过例如:
enum { max_data_length = 3 }; //8KB
unsigned char stream_data_[max_data_length];
stream_data_[0] = 20;
stream_data_[1] = 30;
stream_data_[2] = 40;
char str[16];
sprintf(str, "%X02 ", stream_data_);
std::cout << str;
但我无法理解为什么每次运行时结果总是不同的。 例如:
C2CA426002
7C92553002
答案 0 :(得分:2)
唯一的问题是iostream将unsigned char
视为字符类型,
而不是一个小整数。要解决此问题,只需将unsigned
char
投射到unsigned
,然后再将其输出。 (其余的:你必须这样做
当然,请指定十六进制输出,可能还有宽度和填充字符。)
转储unsigned char
:
void
dumpArray( unsigned char const* array, int count, std::ostream& dest )
{
dest.setf( std::ios_base::hex, std::ios_base::basefield );
dest.fill( '0' );
while ( count > 0 ) {
dest << std::setw( 2 ) << static_cast<unsigned>( *array );
-- count;
if ( count != 0 ) {
dest << ' ';
}
}
}
(当然,在生产代码中,您需要保存以前的格式, 并在返回之前恢复它。)