C语言中sizeof与strlen区别
sizeof 初始的分配的空间大小,期中
(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
char *c="abcdef";
char d[]="abcdef";
char e[]={'a','b','c','d','e','f'};
printf("%d%d/n",sizeof(c),strlen(c));
printf("%d%d/n",sizeof(d),strlen(d));
printf("%d%d/n",sizeof(e),strlen(e));
输出的结果是:
4 6
7 6
6 14
分析一下:
第一行定义c为一个字符指针变量,指向常量字符串,c里面存放的是字符串的首地址。
第二行定义d为一个字符数组,以字符串的形式给这个字符数组赋值。
第三行定义的也是个字符数组,以单个元素的形式赋值。
当以字符串赋值时,"abcdef",结尾自动加一个"/0".
strlen(c)遇到/0就会结束,求的是字符串的长度,为6.
sizeof(c)求的是类型空间大小,在前面说过,指针型所点的空间大小是4个字节,系统地址总线长度为32位时。
strlen(d)也是一样,字符串赋值,自动添加/0,求字符串的长度当然是6.
sizeof(d)是求这个数组所占空间的大小,即数组所占内存空间的字节数,应该为7.
sizeof(e), 数组e以单个元素赋值,没有/0结束符,所以所占空间的大小为6个字节。
strlen(e),去找/0结尾的字符串的长度,由于找不到/0,所以返回的值是一个不确定的值。