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; }
</pre><p>注:C++指针转换,参见C++primer 第四版 5.12.3</p><p>在使用数组时,大多数情况下数组会自动转换为指向第一个元素的指针,不将数组转换为指针的情况有:数组用作取地址(&)操作符的操作数或sizeof的操作数,或用数组对数组的引用进行初始化时,不会将数组转换为指针,如下:</p><p></p><pre code_snippet_id="265026" snippet_file_name="blog_20140330_1_2630334" name="code" class="cpp">#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; }输出为:
sizeof int=4
20
4
20
4
20
多维数组情况是一样的
#include <iostream> int main(int argc,char**argv){ int a[4][4]; int b[2][3][2]; std::cout<<sizeof(a)<<std::endl; std::cout<<sizeof(b)<<std::endl; }64
C++中传递数组的引用
#include <iostream> void getL(int a[3]){ std::cout<<sizeof(a)<<std::endl; } void getL1(int (&a)[3]){ std::cout<<sizeof(a)<<std::endl; } int main(int argc,char**argv){ int a[3]; getL(a); getL1(a); }4(32位机)
12