#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) ) 的解释
来源:互联网 发布:防火墙软件测试报告 编辑:程序博客网 时间:2024/04/30 02:22
原文地址:http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=814501
_INTSIZEOF(n)的宏是实现在不同平台下,关于字节对齐的计算所用。
对于两个正整数 x, n 总存在整数 q, r 使得
x = nq + r, 其中 0<= r <n //最小非负剩余
q, r 是唯一确定的。q = [x/n], r = x - n[x/n]. 这个是带余除法的一个简单形式。在 c 语言中, q, r 容易计算出来: q = x/n, r = x % n.
所谓把 x 按 n 对齐指的是:若 r=0, 取 qn, 若 r>0, 取 (q+1)n. 这也相当于把 x 表示为:
x = nq + r', 其中 -n < r' <=0 //最大非正剩余
nq 是我们所求。关键是如何用 c 语言计算它。由于我们能处理标准的带余除法,所以可以把这个式子转换成一个标准的带余除法,然后加以处理:
x+n = qn + (n+r'),其中 0<n+r'<=n //最大正剩余
x+n-1 = qn + (n+r'-1), 其中 0<= n+r'-1 <n //最小非负剩余
所以 qn = [(x+n-1)/n]n. 用 c 语言计算就是:
((x+n-1)/n)*n
若 n 是 2 的方幂, 比如 2^m,则除为右移 m 位,乘为左移 m 位。所以把 x+n-1 的最低 m 个二进制位清 0就可以了。得到:
(x+n-1) & (~(n-1))
- #define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) ) 的解释
- 内存对齐#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) )
- 内存对齐#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) )
- 内存对齐#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) ) .
- 内存对齐#define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) )
- ((sizeof(n)+sizeof(int)-1)&~(sizeof(int)-1))
- 计算字节对齐的地址 ((sizeof(n)+sizeof(int)-1)&~(sizeof(int)-1))
- sizeof(int)
- memset(a, -1, sizeof(int)) 的理解
- memset(a, -1, sizeof(int)) 的理解
- #define MenuWhat(n) {(U8 **)n,(sizeof(n)/sizeof(U8 *))}
- C语言之sizeof详解 eg: int i = 10; printf("sizeof(i++) is: %d\n",sizeof(++i));
- sizeof(int)*nCount
- sizeof(int/long/...)
- 【C++学习之路】sizeof(array)/sizeof(int)的含义
- 不使用sizeof, 计算int的位数...
- 不使用sizeof计算int的大小
- 不使用sizeof, 计算int的位数
- No Application ID has been found错误提示。
- 黑马程序员-IO流
- 不知所措的青春
- Bp网络神经算法
- C/C++_猜数字游戏
- #define _INTSIZEOF(n) ((sizeof(n)+sizeof(int)-1)&~(sizeof(int) - 1) ) 的解释
- 卫星导航-我们必须发展北斗
- unistd.h 及execve函数
- 给查询出的SQL记录添加序号列(转,很实用!)
- nyoj 485
- 在RAD中开发、配置并测试基于Session Bean的Scheduler任务
- 递归
- Linux服务器搭建之十七:服务器操作系统搭建轻量级桌面
- 万进制,乘法