sizeof是C语言中保留关键字,也可以认为是一种运算符,单目运算符。常见的使用方式:
-
int a=
10;
-
int arr=[
1,
2,
3];
-
char str[]=
"hello";
-
int len_a =
sizeof(a);
-
int len_arr =
sizeof(arr);
-
int len_str =
sizeof(str)
-
-
printf(
"len_a=%d,len_arr=%d,len_str=%d\n",len_a,len_arr,len_str)
看了上面的代码,一般会认为结果是:len_a=1,len_arr=3,len_str=5
实际上的结果是:len_a=4,len_arr=12,len_str=6
sizeof还可以这么用:
printf("len_int=%d,len_short=%d,len_double=%d", sizeof(int), sizeof(short), sizeof(double));
获取某个数据类型所占用空间的字节数。
再来看另外一段代码:
-
#include<stdio.h>
-
-
void main(){
-
int a =
10;
-
char b =
'b';
-
short c =
2;
-
long d =
9;
-
float e =
6.29f;
-
double f =
95.0629;
-
int arr[] = {
1,
2,
3 };
-
char str[] =
"hello";
-
double *p=&f;
-
int *i=&a;
-
//分别对各个变量使用sizeof运算
-
printf(
"a=%d,b=%d,c=%d,d=%d,e=%d,f=%d,arr=%d,str=%d point_p=%d,point_i=%d\n",
-
sizeof(a),
sizeof(b),
sizeof(c),
sizeof(d),
sizeof(e),
sizeof(f),
-
sizeof(arr),
sizeof(str),
sizeof(p),
sizeof(i));
-
-
system(
"pause");
-
}
-
输出的结果是:a=
4,b=
1,c=
2,d=
4,e=
4,f=
8,arr=
12,str=
6 point_p=
4,point_i=
4
看了这些结果,应该也能逆推出来sizeof的含义了吧。
sizeof实际上是获取了数据在内存中所占用的存储空间,以字节为单位来计数。
C语言会自动在在双引号""括起来的内容的末尾补上"\0"代表结束,ASCII中的0号位也占用一个字符。
注意,了解了sizeof的真正含义后。类似如下的代码就很low了。
-
int arr[]={
1,
2,
3};
-
for(
int i=
0;i<
sizeof(arr);i++){
-
printf(
"%d,",arr[i]);
-
}
-
除了会输出
1,
2,
3以外,还会输出杂乱无章的数字,但一共是输出
12个。
-
因为数组的内存是动态分配的,到了元素
3以后的元素都是新分配的,并不一定是空。
-
因为数组是一片连续的空间,有可能元素
3的空间是有数据的,那么C语言会将其读取出来,
-
当然是一些没有实际意义的杂乱无章的数字,但你不要想着去操作,否则可能导致数据错乱
-
所以有可能你运行好几次,后面的值都不会有变化。
-
-
不过改成如下代码,就很精辟了。
-
-
int arr[]={
1,
2,
3};
-
for(
int i=
0;i<(
sizeof(arr)/
sizeof(
int));i++){
-
printf(
"%d,",arr[i]);
-
}
C/C++中,sizeof()只是运算符号,是编译的时候确定大小的。动态分配是运行过程中得到大小的,也就是说C++中new出来的内存,sizeof都无法统计的,退一步说,即使是new出来的空间也有可能失败,所以sizeof无法统计动态分配的内存大小。
例如:
-
//使用new关键字,在堆区开辟一个int数组
-
int* arr =
new
int[
5]{
1,
2,
3,
4,
5};
-
//并不是计算数组arr所占用的内存空间大小,而是计算指针所占内存大小,32位系统指针占4字节,64位系统指针占8字节
-
cout <<
sizeof(arr) <<
endl;
-
//解指针,因为arr指针指向的时数组的首元素,所以实际计算的是int类型的数据所占用内存空间,int类型占4字节
-
cout <<
sizeof(*arr) <<
endl;
转载:https://blog.csdn.net/u013812502/article/details/81198452
查看评论