QString front="ABCDEFG";
QByteArray sendBuf = QByteArray::fromHex(front.toLatin1());
qDebug()<<qPrintable(sendBuf.toHex());
如上述代码,在我们需要把字符串转十六进制的QByteArray数组时,这样可以是可以,但是如果字符串是奇数,如上,打印出来的是“0abcdefg”,自动添加了一个'0',这是因为fromHex()
方法会在字符串前面添加一个字符'0'
,使其长度变为偶数,所以最后就变成了“0ABCDEFG”。
在进行串口编程的时候,这就是个大麻烦。比如串口传输十六进制的指令,如果添加了这个0,那么设备就会无法识别这条指令了,怎么避免我也不知道,我的办法就是:
1.规避其奇数长度的指令,指令格式规定为偶数,那样就不会出错了。
2.使用其他方法。
3.你不需要通过串口发送出去十六进制的数据,只需要打印出来,代码如下:
QString str = "ABCDEFG";
QByteArray ba = str.toLocal8Bit();
qDebug()<<qPrintable(ba.data());
或者转换其他类型数据:
QString str = "ABCDEFG";
QByteArray ba = str.toLocal8Bit();
char path[50];
memcpy(path, ba.data(), ba.size() + 1);
qDebug()<<qPrintable(path);
出现自动补0的现象原因:
QByteArray以字节存储数据,这里字符串长度如果是奇数,则最高字节数只能是半个字节了,所以最高位是0开头,如果你的数据是要求发送规定协议的格式那么可能是数据组织出错(规定的协议就是奇数长度,那直接修改解析方案就行了)。