0

我们如何将#defined 宏作为函数接受引用的参数传递给函数。

这就是我尝试错误的方式:

#define RST_REQ_REG 0x04
#define RESET_CMD   0x01

write_register(RST_REQ_REG, RESET_CMD, 1);


// Decleration of write_reg is
void write_register(uint8_t regAddr, uint8_t *writeByte, uint8_t writeByteLen);

谢谢 !

4

2 回答 2

2

你不能。write_register接受一个指针作为第二个参数,句点。

你可能想要这个:

#define RST_REQ_REG 0x04
#define RESET_CMD   0x01

uint8_t cmdbuffer[1] = {command};

write_register(RST_REQ_REG, cmdbuffer, 1);

也许您想将其包装到另一个函数中:

void write_command(uint8_t regAddr, uint8_t command)
{
   uint8_t cmdbuffer[1] = {command};
   write_register(regAddr, cmdbuffer, 1);
}

...
write_command(RST_REQ_REG, RESET_CMD);
于 2016-05-04T07:35:17.193 回答
1

由于您必须将指针传递给 write_register 函数,因此您必须首先将其分配给一个变量,以便它获得分配的存储空间。它不能作为文字传递。为什么 write_register 需要一个指针,可能是如果你想写入多个字节,那么你可以传递一个数组(C 中的数组只是指向数组第一个元素的指针),但是如果你总是想写入 1 个字节它会变得烦人。

所以你需要做这样的事情:

uint8_t byteToWrite = RESET_CMD;
write_register(RST_REQ_REG, &byteToWrite, 1);

如果这种情况经常发生并且让您烦恼,您可以编写一个包装函数:

static void my_write_register(uint8_t regAddr, uint8_t writeByte)
{
  write_register(regAddr, &writeByte, 1);
}

然后你可以这样称呼它:

my_write_register(RST_REQ_REG, RESET_CMD);
于 2016-05-04T07:40:17.360 回答