这里遇到字符串结束符不是偶然的。对于数组,C语言规定,若没有初始化列表,则仅分配空间,对应内存区域为随机值(实际情况视编译器而定,例如Microsoft C编译器Debug模式下会用0xcc填充这些区域以便辨认);若存在初始化列表,则按初始化列表的各项的值依次填充至数组中;长度不够的,顺序初始化结束后,用0填充剩余部分。这里数组声明中长度为10,也就是a能容纳10个char变量。初始化后a的内容应该为'a','b',0,0,0,0,0,0,0,0,strlen(a)从地址a(等于&a[0],即'a'的位置)开始计算长度,到'b'之后遇到结束符&a[2]处的0停止,因此结果为&a[2]-&a[0]=2。LZ可以自行逐个输出a的各个字符元素查看'b'之后的实际内容。
====
[原创回答团]
这里计算a里,从&a[0]起始的字符串长度。
char a[10]={'a','b'}; 得2
char a[10]={'a','b','c'}; 得3
char a[10]={'a','b','c'}; a[9]='9'; 仍然得3.
字符串长度,不计字符串结束符。它与字符串占据的存放单元个数概念不同。
字符串结束符是 '\0' (或 "\0" ,同null)
char a[10]={'a','b'};
这时候数组a中的其他字符被自动初始化为‘\0'。
有兴趣的话楼主可以用一个for循环输出。
printf("%d",a[2]);//输出0,改成%c的话,输出一个空格,所以该字符即'\0',因此,slen()到这里就遇到了空白字符,因此是2
printf("%d",a[3]); //输出0,改成%c的话,输出一个空格,所以该字符即'\0'