我在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
类的示例(仅包含sstream
和iomanip
标准标头):
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++方法。