INTSIZEOF 宏, 位运算 与乘除的关系

本文深入探讨了INTSIZEOF宏的实现原理,该宏用于计算数据类型所占用的空间,并确保其为int类型的整数倍。文章通过球盒比喻,直观解释了公式(n+m-1)/m*m的由来,即(n+m-1)&~(sizeof(type)-1),并证明了其正确性,条件为m=2^x。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

INTSIZEOF 宏,获取类型占用的空间长度,最小占用长度为int的整数倍

#define _INTSIZEOF(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )

首先有以下证明:
先举个例子,假设一个盒子能放2个球,目前有6个球,那么就需要3个盒子,若是有5个球,那么还是需要3个盒子。扩展一下,若是有n个球,每个盒子能容乃下m个球,那么需要多少个盒子???这里直接给出结论就是(n + m - 1)/m个。

若m为sizeof(type);最小占用长度为type的整数倍
则 (n+m-1)/m*m = ((n + m - 1)>>x)<<x = (n + m - 1)& ~(sizeof(type) - 1)
成立的条件为:m = 2^x次方(x为整数)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值