我有一个C ++应用程序,该应用程序具有许多由不同应用程序调用的API。 C ++应用程序的功能之一是
long void ConvertHexToDec (char* hex, int size)
{
// hex - Hex value passed in as char pointer
// size - size in bytes
//Now for e.g., if the values are ...
// hex = 567D & size = 2
for (int i = 0; i < size; i++)
{
printf ("hex[i] = %x", i, hex[i]);
}
// the above FOR loop will print
// hex[0] = 56
// hex[1] = 7D
// I was hoping to get each digit in a separate index like, hex[0] = 5, hex[1] = 6, hex[2] = 7, hex[3] = D
//the application that calls this C++ API is reading values from a hardware
//device and get the values in hex, and then call this API to convert it to
//decimal.
//so in above example it reads memory location 0xB10A and get a 2 byte value
//of 567D
//I see many examples of hex to decimal conversion in C++, but all of them
//uses logic to convert by taking one value at a time.
//so from above example, it will start at D and then convert that to decimal
//and then take 7 and convert that and then next and so on......
//Here there's no way i can do that, as every byte has 2 digits in it.
//And this is my challenge and i have no idea...
}
我尝试过的事情:
string str;
str = "";
for (int i = 0; i < size; i++)
{
printf ("hex[i] = %x", i, hex[i]);
str += hex[i];
}
//But when i print out string value it again comes out as....
for (int i = 0; i < size; i++)
{
printf ("str[i] = %x", i, str[i]);
}
//str[0] = 56
//str[1] = 7D
也尝试过
std::hex // this gives a junk "decimal" value and that's no where close to the
//real decimal value.
同样,也不会一次一位地获取每个数字以将其转换为十进制。
那么我该怎么做才能将这种包含十六进制的char指针转换为十进制?
答案 0 :(得分:1)
根据代码块中的描述,似乎不需要字符串或复杂的转换。他们似乎只想将big-endian字节数组转换为native-endian数字。
代码中嵌入的注释,可能需要更多说明或警告。
//long void ConvertHexToDec (char* hex, int size) has been changed to
long ConvertHexToDec (const char* hex, int size)
// const char * much more versatile than char * and since we aren't changing hex
// might as well make it const. And what the heck is a long void? A big nothing?
{
long result = hex[0]; // assuming hex not NULL and size > 0
for (int i = 1; i < size; i++) // loop until out of bytes. Note: long might only
// hold 4 bytes.
{
result <<= 8; // shift current data over one byte
result += (unsigned char)hex[i]; // add in new byte. Cast required to avoid sign
// extension during the math if char happens to
// be signed. Note that overflow of the long
// can bring nasty surprises of its own
}
return result;
}
对于类似这样的东西,我通常使用the fixed width integers in cstdint
而不是long
和char
之类的类型。它可以防止非常令人讨厌的意外。在这里,我要重写
uint32_t ConvertHexToDec (const uint8_t* hex, size_t size)
{
if (size > 0 || size <= sizeof(uint32_t)) // no surprises. Up to 4 bytes regardless
// of target, and no signed overflow.
{
uint32_t result = hex[0];
for (size_t i = 1; i < size; i++)
{
result <<= 8;
result += hex[i];
}
return result;
}
throw std::out_of_range("Invalid size"); // can't convert = no result
}
请注意,您可能必须将返回的uint32_t
转换为签名类型。通常最好在通话后再执行此操作,并且您已经测试并确认所阅读的内容有效且可用。
答案 1 :(得分:0)
我假设参数char *十六进制包含您可以直接读取的物理地址。
然后使用
long ConvertHexToDec2Bytes(char* hex)
{
const auto n = *(short*)hex;
#ifdef WANNA_COUT
std::cout << n << std::endl;
#endif
#ifdef WANNA_STRING
const auto str = std::to_string(n);
#endif
return n;
}
也许您想转换4字节或8字节,但实际上并没有太大的不同。