在VS C ++中将LPCTSTR HEXADECIMAL转换为BYTE

时间:2018-10-31 15:20:29

标签: c++ string winapi visual-studio-2017 byte

我具有下面的功能,支持将LPCTSTR转换为BYTE,但是到目前为止,输入的str仅支持数字。

void StrToByte2(LPCTSTR str, BYTE *dest)
{
    UINT count = _ttoi(str);
    BYTE buf[4] = { 0 };
    char string[10] = { 0 };
    sprintf_s(string, 10, "%04d", count);
    for (int i = 0; i < 4; ++i)
    {
        if ((string[i] >= '0') && (string[i] <= '9'))
            buf[i] = string[i] - '0';
    }
    dest[0] = (BYTE)(buf[0] << 4) | buf[1];
    dest[1] = (BYTE)(buf[2] << 4) | buf[3];
}

如果我在“ 1234”(任意数字)上调用此函数,dest输出一些12814,

struct st               
{
    byte    btID[2];
    int     nID;
};

PTR ptr(new st);
StrToByte2(strCode, ptr->btID);

但是当我在任何十六进制ex A123上调用此函数时,它总是输出0000。

以下功能用于将dest代码转换回str

CString Byte2ToStr(const byte* pbuf)
{
    CString str;
    str.Format(_T("%02X%02X"), pbuf[0], pbuf[1]);
    return str;
}

我如何才能将A123转换为字节,然后返回到str以显示A123? 请帮忙!

1 个答案:

答案 0 :(得分:1)

PTR ptr(new st);

这是C ++中的内存泄漏,因为new st分配了内存,无法释放它。

UINT count = _ttoi(str);
...
sprintf_s(string, 10, "%04d", count);

这是将字符串转换为整数,然后将整数转换回字符串。它似乎没有真正的目的。

例如,"1234"转换为1234,然后又转换回"1234"。但是"A123"不是有效数字,因此将其转换为0,然后转换为"0000"。因此此方法失败。您可以只使用原始字符串。

似乎此函数尝试将2个整数适合1个字节。只要每个值都小于160xF,就可以做到这一点(我不知道这可能有什么目的)。可以将其固定如下:

void StrToByte2(const wchar_t* str, BYTE *dest)
{
    int len = wcslen(str);
    if(len != 4)
        return; //handle error
    char buf[4] = { 0 };
    for(int i = 0; i < 4; ++i)
        if(str[i] >= L'0' && str[i] <= L'9')
            buf[i] = (BYTE)(str[i] - L'0');
    dest[0] = (buf[0] << 4) + buf[1];
    dest[1] = (buf[2] << 4) + buf[3];
}

CStringW Byte2_To_Str(BYTE *dest)
{
    CStringW str;
    str.AppendFormat(L"%X", 0xF & (dest[0] >> 4));
    str.AppendFormat(L"%X", 0xF & (dest[0]));
    str.AppendFormat(L"%X", 0xF & (dest[1] >> 4));
    str.AppendFormat(L"%X", 0xF & (dest[1]));
    return str;
}

int main()
{
    BYTE dest[2] = { 0 };
    StrToByte2(L"1234", dest);
    OutputDebugStringW(Byte2_To_Str(dest));
    OutputDebugStringW(L"\n");
    return 0;
}

如果字符串为十六进制,则可以使用sscanf将每对字符转换为字节。

基本上,"1234"更改为12 34
"A123"更改为A1 23

bool hexstring_to_bytes(const wchar_t* str, BYTE *dest, int dest_size = 2)
{
    int len = wcslen(str);

    if((len / 2) > dest_size)
    {
        //error
        return false;
    }

    for(int i = 0; i < len / 2; i++)
    {
        int v;
        if(swscanf_s(str + i * 2, L"%2x", &v) != 1) 
            break;
        dest[i] = (unsigned char)v;
    }

    return true;
}

CStringW bytes_to_hexstring(const BYTE* bytes, int byte_size = 2)
{
    CString str;
    for(int i = 0; i < byte_size; i++)
        str.AppendFormat(L"%02X ", bytes[i] & 0xFF);
    return str;
}

int main()
{
    CStringW str;
    CStringW new_string;

    BYTE dest[2] = { 0 };

    str = L"1234";
    hexstring_to_bytes(str, dest);
    new_string = bytes_to_hexstring(dest);
    OutputDebugString(new_string);
    OutputDebugString(L"\n");

    str = L"A123";
    hexstring_to_bytes(str, dest);
    new_string = bytes_to_hexstring(dest);
    OutputDebugStringW(new_string);
    OutputDebugStringW(L"\n");

    return 0;
}