最近写单元测试程序发现对char *buf这种形式的理解还是不透彻,不想翻理论了,写几个程序看下编译器究竟是如何处理的
我的环境是:
编译器:arm-hismall-linux-gcc
linux内核:2.6.14
CPU:海思3512
编译命令:arm-hismall-linux-gcc a.c -Wall -o a.out
int main()
{
// char *buf = "";
// char *buf = "/0";
char *buf = NULL;
if(buf == NULL)
printf("NULL/n");
else
printf("(%d)/n", *buf);
}
那么输出是怎么样的呢(每个输出对应上面char *buf = 的一行)
由此可以看出,除非一个指针指向0或者NULL(其实NULL就是0),也就是说一个指针要显式的赋给0,那么编译器会认为这是一个空指针;
反之,如果是字符串长度为0(第一种情况)和/0(第二种)的话,会认为这里存放的是一个值为0的指针.
我很感兴趣的是那么前2种情况的长度是多少呢?0还是1,再次验证
那么输出为
也就是说空字符串和仅仅含有 \0 的字符串的长度为0.