今天敲代码时候,要计算发送的字符串大小,如下:
char *p = "hello world";
int len1 = sizeof(p)/sizeof(char);
结果,不管我怎么改变字符串长度,len1都是等于4(这个值在不同平台和不同编译器不一样)。
后来查了一下,才发现自己错了,现总结一下。
1. sizeof
sizeof是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、数据类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构体或数组所占的空间,返回值跟对象、结构、数组所存储的内容 没有关系。
具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:
- 数组名——编译时分配的数组空间大小;
- 指针变量——存储该指针所用的空间大小;
- 数据类型——该类型所占的空间大小;
- 对象——对象的实际占用空间大小;
- 函数——函数的返回类型所占的空间大小,函数的返回类型不能是void。
2. strlen
strlen是函数,要在运行时才能计算。参数必须是字符型指针(char*),当数组名作为参数传入时,实际上数组就退化成指针了。
它的功能是:返回字符串的长度。
该字符串可以是自己定义的,也可以是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符NULL(\0),返回的长度大小不包括NULL(\0)。
3. 举例
char arr[10] = "hello";
int len1 = sizeof(arr);
int len2 = strlen(arr);
printf("%d and %d",len1,len2);
输出结果是:10 and 5
分析:sizeof返回定义arr数组时,编译器为其分配的数组空间大小,不关心里面存了多少数据。strlen只关心存储的数据内容,不关心空间的大小和类型。