将二进制十六进制数据转换为 ASCII 等效数据并存储在字符串中



我在Arduino上使用C++。

假设我有一个二进制数据流;

二进制数据:0xFF, 0x00, 0x01, 0xCC

我想将其转换为 ASCII 等效项并将其存储在字符串对象类型中。

转换后的字符串应如下所示"FF0001CC"。

以下是一些代码草案。

char buffer[100];
String myString;
for (int i=0; i < numBytes; i++)
{
    //assume buffer contains some binary data at this point 
    myString += String(buffer[i], HEX);
}

这段代码的问题在于myString包含FF01CC,而不是FF0001CC

我的猜测是,每次附加文本时,String 类都会调整大小,这可以改进。假设您知道输入大小并且它是恒定的,您可以尝试以下操作:

char outbuffer[numBytes*2+1];   
const char* pHexTable="0123456789ABCDEF";
int iPos=0;
for(int i=0; i<numBytes; i++){
    //assume buffer contains some binary data at this point
    const char cHex=buffer[i];
    outbuffer[iPos++]=pHexTable[(cHex>>4)&0x0f];
    outbuffer[iPos++]=pHexTable[cHex&0x0f];
}
outbuffer[iPos]='';

C++中提供了字符串流类,在这种情况下可以使用。使用 C 时,三个字节将被打印到带有一个 sprintf 语句sprintf(buffer, "%02x%02x%02x", bytes[0], bytes[1], bytes[2])(最好是snprintf)的缓冲区。

#include <sstream>
#include <iostream>
#include <iomanip>
int main(void)
{
    std::stringstream ss;
    unsigned char bytes[] = {0xff, 0x00, 0xcc};
    ss << std::hex;
    // This did not work, 00 was printed as 0
    // ss << std::setfill('0') << std::setw(2)
    // ...
    // ss << (unsigned int)bytes[i]
    for (int i=0; i<3; i++) {
       unsigned int tmp = bytes[i];
       ss << (tmp >> 4) << (tmp & 0xf);
    }
    std::cout << ss.str();
    return 0;
}

据了解numBytes可以大于 3 或 4(否则为什么缓冲区大小为 100?此外,在使用string时,我更喜欢使用C++类(您需要string,而不是char[]

考虑以下包含stringstream类的示例(仅包含sstreamiomanip标准标头):

    string myString;
    stringstream myStringStream;
    myStringStream << setbase(16);
    myStringStream << uppercase;
    for (int i = 0; i < numBytes; i++)
    {
        myStringStream << (0xFF & (unsigned int) buffer[i]);
    }
    myString = myStringStream.str();

无法将我的示例的速度与其他答案进行比较,但对于任何规模的buffer来说,这个解决方案确实C++方法。

相关内容

  • 没有找到相关文章

最新更新