如何添加2个四位Hexa来生成ASCII字节

时间:2012-08-23 15:51:49

标签: c++

我有一个来自源的二进制文件,我必须从中检索数据,以便以人类可读的形式读取。我已经重新获取了数据并将其保存在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值。我现在的做法是只添加这两个,但这是正确的方法吗?谢谢

2 个答案:

答案 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];