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 因为找不到结束符,会继续的计算直到
找到结束符为止。因此这个数是不肯定.spa
实例2:指针
char a[]="hello";内存
char b[]={'h','e','l','l','o'};字符串
strlen(a),strlen(b)的值分别是多少?io
前面分析过,strlen是求字符串的长度,字符串有个默认的结束符/0,这个结束符是在定义字符串的时候系统自动加上去的,就像定义数组a同样。数组a定义了一个字符串,数组b定义了一个字符数组。所以,strlen(a)=5,而strlen(b)的长度就不肯定的,由于strlen找不到结束符。class
-------------------------test
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)---5float
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,因此返回的值是一个不肯定的值。