将Char指针中的十六进制转换为十进制

时间:2018-06-28 00:46:36

标签: c++ visual-c++

我有一个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指针转换为十进制?

2 个答案:

答案 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而不是longchar之类的类型。它可以防止非常令人讨厌的意外。在这里,我要重写

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字节,但实际上并没有太大的不同。