我正在学习XINU,并遇到了这个简单的单行函数.是否可以解释这个函数是如何工作的,并将x舍入到最近的块大小以进行内存分配?如果查询太简单,请不要介意。
我也很困惑,为什么要将它更改为字符指针。
/*----------------------------------------------------------------------
*roundmb, truncmb - round or truncate address to memory block size
*----------------------------------------------------------------------
*/
#define roundmb(x) (char *)( (7 + (uint32)(x)) & (~7) )链接到完整的XINU代码:https://github.com/xinu-os/xinu/blob/master/include/memory.h
发布于 2018-10-19 00:08:15
因此,这是下一个因子8。
打开传入的值被转换为一个数字,所以我们可以对它进行适当的数学计算。
第一个真正的步骤x+ 7,这推动了值的上升,所以我们只需要舍入。
0 -> 7
1 -> 8
2 -> 10
7 -> 14
8 -> 15
9 -> 16~7是位掩码,0xFFFFFFFF8。我会简化和使用0xF8时,处理它的小数字。
然后将附加值与位掩码组合起来。基本上我们放弃了最后三位。
0 -> 7 -> 0
1 -> 8 -> 8
2 -> 10 -> 8
7 -> 14 -> 8
8 -> 15 -> 8
9 -> 16 -> 16然后将这个数字转换为一个内存地址,取消初始的uint强制转换。因为您正在处理内存块,并且可能正在访问它们中的数据,因此将其作为指针更有意义。
https://stackoverflow.com/questions/52883965
复制相似问题