(1)char * 指针
strlen(指针名)
如果参数是指针则计算该指针指向字符序列的长度。(以’\0’ 作为判断标志)例如:
定义char *p=“hello world”;strlen(p)=11,而 sizeof (p)=4。可以看到 strlen
计算的是指针指向的字符串的长度而sizeof 计算的是指针本身所占用的内存空
间的大小。
(2)数组
strlen(数组名)
如果参数是数组的话,实际传递的是一个指针,strlen 会按照上面处理指针的模
式处理该数组。
我们可以看下面的例子:
char a[]=”hh”;
strlen(a);
很显然strlen 的结果是2。但是如果数组是这样赋值的呢?
char a[]={‘h’,’h’};
strlen(a);
那么现在strlen(a )的结果又是多少呢?这个数就不一定了,原因是 strlen 会去
计算a 地址开始的字符串的长度,由于前一种赋值方式会将hh以字 符串的形式
赋值给数组会将字符串结束符’\0’ 一同赋值,这时strlen 就会检查到结束符停止
计算,而第二种复值方式是以单个字符的形式赋值没有结束 符’\0’, 这时我们用
sizeof 得到的结果是正常的,而用 strlen 由于找不到结束符,会继续的计算直到
找到结束符为止。所以这个数是不确定.
实例2:
char a[]="hello";
char b[]={'h','e','l','l','o'};
strlen(a),strlen(b)的值分别是多少?
前面分析过,strlen是求字符串的长度,字符串有个默认的结束符/0,这个结束符是在定义字符串的时候系统自动加上去的,就像定义数组a一样。数组a定义了一个字符串,数组b定义了一个字符数组。因此,strlen(a)=5,而strlen(b)的长度就不确定的,因为strlen找不到结束符。
-------------------------
One example
#define PATH_TMP "12345"
static void test_sizeof_strlen() {
char *msg = "12345";
printf("sizeof(msg)---%d\n" , sizeof(msg));
printf("strlen(msg)---%d\n" , strlen(msg));
char array[] = "12345";
printf("sizeof(array)---%d\n" , sizeof(array));
printf("strlen(array)---%d\n" , strlen(array));
printf("sizeof(PATH_TMP)---%d\n" , sizeof(PATH_TMP));
printf("strlen(PATH_TMP)---%d\n" , strlen(PATH_TMP));
}
The output result:
sizeof(msg)---4
strlen(msg)---5
sizeof(array)---6
strlen(array)---5
sizeof(PATH_TMP)---6
strlen(PATH_TMP)---5