第一点是:没有十六进制数字这样的东西。数字就是数字。我们在这里谈论整数。不管你说 16、0x10、020 等等,都是同一个数字。 0x10 仅在您以十六进制表示法写出的意义上是“十六进制”。它不会改变数字本身的任何内容,也不会使其成为“十六进制”!它仍然是从零递增 16 次得到的数字。
使用十六进制的唯一原因可能是设备的文档以十六进制提供了命令包。这是一个完全武断的选择。您可以从文档中复制十六进制数字,或者如果对您更有意义,将它们转换为另一个基数。
所以,十六进制表示当然完全取决于您,您不需要明确使用它。但是您确实需要以某种方式使用 C 常量数组 - 它们使事情变得简单且开销低。假设您的命令由三个字节组成,十进制值为 16、33、47。
你可以这样编码:
static const char cmdBuf[] = { 16, 33, 47 };
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf));
字节数组cmd是在不复制数据的情况下初始化的,这样既快速又高效。 cmdBuf 必须是静态的,因为它必须与 cmd 或其任何(浅)副本一样存在。
您可以使用字符串文字来初始化数组,对不可打印字符使用十六进制转义符,否则使用可打印字符。
static const char cmdBuf[] = "\x10!/";
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf)-1);
sizeof(...)-1 的原因是 cmdBuf 有 4 个字节长 - 字符串文字以您并不真正需要的终止零结尾。
如果您希望对所有字节使用十六进制表示,则可以
static const char cmdBuf[] = "\x10\x21\x2F";
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf)-1);
// or
static const char cmdBuf[] = { 0x10, 0x21, 0x2F };
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf));
当然你也可以使用八进制:
static const char cmdBuf[] = "\020\041\057";
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf)-1);
// or
static const char cmdBuf[] = { 020, 041, 057 };
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf));
或者它们的任意组合!
static const char cmdBuf[] = "\020\x21/";
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf)-1);
//or
static const char cmdBuf[] = { 16, 0x21, 057 };
const auto cmd = QByteArray::fromRawData(cmdBuf, sizeof(cmdBuf));
在字符串文字中,是否将其全部编码为十六进制/八进制转义符或使用可打印字符取决于您,这是样式问题。如果您的命令中的值不具有可打印字符的含义,那么字符串文字或数组初始值设定项中的数字(十六进制或八进制)编码可能会更好。
在八进制和十六进制之间进行选择时,请遵循命令字节的结构或您自己的偏好。如果字节的结构以某种方式分解为 2+3+3 位组,那么八进制是使其易于阅读的好方法。否则,使用十六进制或十进制。关键在于使代码更易于阅读 - 机器不在乎,无论您采用哪种方式,二进制输出都是相同的。