最近同学叫我帮忙看个问题,为啥这个循环没有退出,
代码如下,原本是想拿到最后的NULL指针就可以结束循环
#include <stdio.h> #include <stdlib.h> #include <stdint.h> #include <string.h> typedef void (*Callback)(int); void call_pin(int input); void call_frequency(int input); struct CMD { char* s; // short name char* l; // long name char c; // long name length(byte) Callback call; // callback function }; struct CMD *cmd = NULL; struct CMD cmds[] = { {"p", "pin", sizeof("pin"), call_pin}, {"f", "frequency", sizeof("frequency"), call_frequency}, NULL }; void call_pin(int input) { printf("%s", __func__); } void call_frequency(int input) { printf("%s", __func__); } int main(int argc, char *argv[]) { cmd = cmds; do { printf("%x ", cmd); printf("%x ", *cmd); } while (++cmd); return 0; }
程序跑起来后while循环没有按照设想的推出,而是一直循环到段错误停止
++cmd在第三次并没有拿到NULL(就是0嘛) 拿到的应该是cmds第三个元素的地址,这个结构体元素的第一个数据是NULL。
后来想了一下如果循环改成
while(*(++cmd))
不久拿到了最后一个NULL了吗,但是代码在编译的时候就提示错误了。
RPiPWMH.c:40:14: error: used struct type value where scalar is required } while (*(++cmd));
while循环判断条件需要的是一个纯标量,但是我们好像返回来的是个结构体
于是把这个转换char指针拿到第一个char的数据也就是NULL
while(*(char *)(++cmd))