我有一个来自源的二进制文件,我必须从中检索数据,以便以人类可读的形式读取。我已经重新获取了数据并将其保存在4位六进制中。例如,文件大小是256字节,我在六进制中检索它并获得512个4位六进制值。 现在,为了使其成为人类可读的ASCII字符,我必须添加两个4位hexa来创建一个字节。我以十六进制格式检索数据的方式是
byte = read_buffer[i];
// Convert the Most Significant nibble for first byte
write_buffer_hex[(i + 1) * 2 + 0] = hex_chars[(byte >> 4)];
// Convert the Least Significant nibble for the first byte
write_buffer_hex[(i + 1) * 2 + 1] = hex_chars[byte & 0x0f];
现在,我的问题是我应该如何添加这两个十六进制值以获得ASCII值。我现在的做法是只添加这两个,但这是正确的方法吗?谢谢
答案 0 :(得分:2)
我同意约翰的看法,直接以十六进制为基础输出它可能更容易:
printf("%x", byte);
或使用C ++的IOstream库:
cout << hex << byte;
答案 1 :(得分:1)
使用查找表:
static char const alphabet[] = "0123456789ABCDEF";
// Loop:
output[cursor++] = alphabet[byte % 16];
output[cursor++] = alphabet[byte / 16];
您也可以直接索引到字符串中:
output[cursor++] = "0123456789ABCDEF"[byte % 16];