理解C语言中的sizeof操作符

友链

sizeof不是函数,就是一个一元运算符,只不过用起来象个函数而已

对于数据类型,sizeof会计算出该数据类型的大小,比如sizeof(int)就是4

但是如果是指针的话

比如

char* a[16];
sizeof(a)的值就是16

char** a[16];
sizeof(a)的值就是64

以前我一直以为

char a[16];

sizeof(a)因该是4,因为a其实就是一个指针,在32位操作系统中,一个指针(内存地址)长度就是32bit即4字节

但是事实证明他会计算出这个指针所指向的内存空间(未分配)的大小,而不是指针类型的大小
在这里插入图片描述
在这里插入图片描述

下面再来看这个:
在这里插入图片描述
在这里插入图片描述

可以从上图中看到,不管是char*还是char**,sizeof都是4,也就是指针的长度

你可能会问,那么这前后到底有什么区别呢

其实很简单,区别就是char cliIp[16]分配了一块静态内存

而如果是使用malloc分配的动态内存,就不会有这个效果:
在这里插入图片描述

你可能又会问了,为什么同样都是内存,使用malloc分配的内存就不会被计算出来呢

那是因为sizoef是一个编译时的运算符,sizoef(xxx)的值并不是在程序运行的时候才被计算出来,而是在编译的时候就已经计算出来了,请看下面的反编译代码
在这里插入图片描述

可以看到这里直接把0x10h(16进制,即10进制的16)作为参数传给了printf函数

这个0x10h是硬编码到程序指令中的,而不是存储在任何寄存器或者内存中

但是malloc只有在程序运行起来之后才会分配内存,这也就是原因所在了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值