总结一下sizeof操作符的一些容易忽略的知识
1.sizeof( )内部不参与运算,内部不会真实访问空间,不会进行计算的
int main()
{
short s = 3;
int a = 12;
printf("%d", sizeof(s = a + 2));
printf("%d", s);
return 0;
}
解析:
int main()
{
short s = 3;//短整形
int a = 12;//整形
printf("%d", sizeof(s = a + 2));
//a是整形,2是整形,相加还是整形,但s是短整形,所以最后的类型还是短整形
//内部不会真实的进行a+2这个计算
printf("%d", s);
//s还是3;
return 0;
2.sizeof()是根据类型来计算大小的,如果知道类型就知道大小
例子:
int main()
{
int a = 10;
printf("%d\n", sizeof(a));
printf("%d\n", sizeof(int));
return 0;
}
例子:
int main()
{
int arr[3][4] = { 0 };
printf("%d", sizeof(arr[3]));
return 0;
}
解析:
int main()
{
int arr[3][4] = { 0 };
//二维数组3行四列
printf("%d", sizeof(arr[3]));
//arr[3]表示第四行数组名,可能你们会想这个数组不是才有3行吗,这不是越界访问了吗
//其实不是的喔,假设这个数组有第四行,那么size(第四行数组名)表示计算的第四行整个大小为16
//想一下,sizeof()其实不会访问真实的空间,它是根据这个arr[3]这个类型来进行判断的
//第四行类型跟第一行第二行第三行类型是一样的都是int[4]类型所以计算出来大小为16.
return 0;
}
3.sizeof VS strlen
1.sizeof只关注占用内存空间的大小,单位是字节,不关心内存中存放的是什么
2.strlen是专门用来求字符串长度的,统计的是’\0’之前出现的字符个数,一定要找到’\0’才能结束,所以如果没有\0可能会存在越界访问问题
3.sizeof是操作符而strlen是库函数