sizeof和strlen
1. sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型,该类型保证能容纳实现所建立的最大对象的字节大小;
2. 本质区别:sizeof是算符,strlen是函数;
3. sizeof可以用类型做参数,strlen只能用char*做参数,而且必须是以''\0''结尾的;
4. 数组做sizeof的参数不退化,传递给strlen就退化为指针了,例:
char str[20]="0123456789";//str是编译期大小已经固定的数组
int a=strlen(str); //a=10;//strlen()在运行起确定
int b=sizeof(str); //而b=20;//sizeof()在编译期确定
此外,sizeof在上编译的时候便已经计算过了,用来维护和定义数组的长度;而strlen则是在运行的时候才计算,是用来计算字符串的实际长度,不是类型占内存的大小。
5. sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数;
6. 当适用了于一个结构类型时或变量, sizeof 返回实际的大小,当适用一静态地空间数组, sizeof 归还全部数组的尺寸。sizeof 操作符不能返回动态地被分派了的数组或外部的数组的尺寸;
7. 数组作为参数传给函数时传的是指针而不是数组,传递的是数组的首地址,例:
fun(char [8])
fun(char [])
都等价于 fun(char *) ;
在C++里参数传递数组永远都是传递指向数组首元素的指针,编译器不知道数组的大小。
例1:
har str[11]="0123456789";//注意这里str大小应该大于等于10,应考虑'\0'在内,否则编译器会报错
int a=strlen(str); //a=10; strlen 计算字符串的长度,以结束符 0x00 为字符串结束。
int b=sizeof(str); //而b=11; sizeof 计算的则是分配的数组 str[11] 所占的内存空间的大小,不受里面存储的内容改变。
例2:
char* ss = "0123456789";
sizeof(ss) 结果4,ss是指向字符串常量的字符指针,sizeof 获得的是一个指针的之所占的空间,应该是长整型的,所以是4;
sizeof(*ss) 结果1,*ss是第一个字符其实就是获得了字符串的第一位'0' 所占的内存空间,是char类型的,占了 1 位strlen(ss)= 10, 如果要获得这个字符串的长度,则一定要使用 strlen。
程序:
#include
#include
int main(void)
{
char a[5];
a[0]='a';
a[1]='c';
a[2]='\0';
a[3]='a';
a[4]='b';
printf("%d\n",sizeof(a));
printf("%d\n",strlen(a));
printf("%d\n",sizeof("abc"));
printf("%d\n",strlen("abc\0d"));
printf("%d\n",sizeof("abc\0d"));
return 0;
}
结果:
5
2
4
3
6
总结:strlen遇到'\0'便认为字符串结束,且不将其计算在内;而sizeof对字符串进行实际的计算,包括'\0'。
注:本文引自
并做了修正和总结。