strlen是用来计算字符串的长度,遇到第一个NULL('\0')为止,不包括‘\0’。
sizeof是用来计算变量或者对象、类型所占字节的多少。
首先来看一个例子:
char s1[] = "hello";
char* s2 = "hello";
char s3[10] = ''hello";
sizeof(s1) = 5 strlen(s1) = 5
sizeof(s2) = 4 (在32位系统是4,在64系统是8) strlen(s2) = 5
sizeof(s3) = 10 strlen(s3) = 5
上面这个例子,根据strlen和sizeof的定义,难以理解的,大概是sizeof(s1)这个值了。首先要明白s2是一个指针,对于指针,sizeof所得值,在32位系统是4,在64系统是8
对于数组,sizeof是计算该数组所占字节数,而不是数组元素个数。
strlen而言,不管是数组还是指针,只要遇到第一个‘\0’就为止,hello字符串是这样的{‘h’, ‘e’,‘l’,‘l’,‘o’,‘\0’}的所以strlen(“hello”) = 5
sizeof可以有这些用法,sizeof(int)、sizeof(2)、sizeof(2+1)、sizeof(f())(int f(),f是一个函数,sizeof是返回值类型的大小,返回值是void,是不能使用sizeof的)等等。
但是位域不能被sizeof计算,这点很重要
sizeof是一个关键字不是函数,发生在编译时刻,所以可以用作常量表达式。
总结如下,当参数分别如下时,sizeof返回的值表示的含义如下:
数组——编译时分配的数组空间大小;
指针——存储该指针所用的空间大小(在32位系统是4,在64系统是8);
类型——该类型所占的空间大小;
对象——对象的实际占用空间大小;
函数——函数的返回类型所占的空间大小。函数的返回类型不能是void
strlen是一个函数,并且所传入的参数必须是char*,发生在运行时刻
sizeof只关心这块内存的大小,不关心这块内存存放了什么数据,strlen只关心这块内存存放的数据,不关心这块内存的大小,直到遇到第一个NULL为止。
现在再来看一个例子,是不是和你们预想的一样
下面这段代码是在64位的ubuntu 16.0.4
运行结果