1.strlen是一个函数,而sizeof是一个操作符,它和解引用操作符*、取地址操作符&具有相同的优先级,具有右结合性,参见C++PRIMER第四版P147
2.strlen是计算字符串中字符的个数,它计算的是从字符串首字符到'\0'前一字符的个数,即不包括'\0'在内。这个函数依赖与'\0‘这个结束标志,这也是C字符串的特点,比如计算下面字符数组的长度时,就会出现问题,char test[5]="enock"; strlen(test);返回的并不是期望的长度,因为没用空间存放'\0'。
sizeof计算的是操作对象所占的字节数,针对静态数组类型(即 type var[])返回的是静态数组元素个数*类型大小,对指针类型,sizeof返回的是指针变量所占的内存大小,32位机,是4Byte,64位机是8Byte如下:
char cvar[20]="enock";
int ivar[20]={1,2,3};
char *cp=new char[5];
printf("%d\n",sizeof(cvar));//20
printf("%d\n",sizeof(ivar));//80
printf("%d\n",sizeof(cp));//4 ,cp是指针变量
(1)需要注意的是参数传递时,静态数组参数会弱化为指针,因为不可能在调用栈上去分配一个数组。所以
void fun(char cvar[]){
printf("%d\n",sizeof(cvar));
}
fun(cvar);//4 32位机指针变量占4个字节
(2)字面值字符串是const char[]类型,即静态数组类型
printf("%d\n",sizeof("enock"));//6,注意结尾'\0'
(3)sizeof(结构体对象),需要注意字节对齐,这跟编译器相关。
参见:sizeof百度百科
2014.3.29阿里巴巴实习生笔试选择题第8题:
下面代码的输出为:
- #include<iostream>
- void f(char*x){
- x++;
- *x='a';
- }
- int main(int argc,char**argv){
- char str[sizeof("hello")];
- strcpy(str,"hello");
- f(str);
- std::cout<<str;
- return EXIT_SUCCESS;
- }
注:C++指针转换,参见C++primer 第四版 5.12.3
在使用数组时,大多数情况下数组会自动转换为指向第一个元素的指针,不将数组转换为指针的情况有:数组用作取地址(&)操作符的操作数或sizeof的操作数,或用数组对数组的引用进行初始化时,不会将数组转换为指针,如下:
- #include<iostream>
- #include<cstdlib>
- void fun1(int a[]){
- std::cout<<sizeof(a)<<std::endl;
- }
- void fun2(int (&a)[5]){//数组的引用
- std::cout<<sizeof(a)<<std::endl;
- }
- int main(int argc,char** argv){
- std::cout<<"sizeof int="<<sizeof(int)<<std::endl;
- int a[5];
- std::cout<<sizeof(a)<<std::endl;
- fun1(a);
- fun2(a);
- int (*p)[5] =&a;
- std::cout<<sizeof(p)<<std::endl;
- std::cout<<sizeof(*p)<<std::endl;
- return EXIT_SUCCESS;
- }
20
4
20
4
20