以下是两个宏定义的方程式
我们在宏定义的过程中一定不要吝色括号,因为宏定义是强制替换,可能会导致一些优先级的问题
首先是交换二进制的奇数位和偶数维
#define SWAP(n) ((n & (0xAAAAAAAA)) >> 1) | ((n & (0x55555555)) << 1)
int main() {
printf("%d", SWAP(170));
}
这里的思路是把这个二进制的奇数位和偶数位都提取出来,分别是AAAAAAAA 和 55555555 ,然后 在把提取出来的分别与输入的数& ,然后再把偶数位左移变成奇数位, 奇数位右移变偶数位,再合并就完事了
struct S
{
char c;
int number;
int n;
};
#define Offsetof(s_name, m_name) ((int)(&((s_name*)0)->m_name))
int main() {
printf("%d\n", Offsetof(struct S, c));
printf("%d\n", Offsetof(struct S, number));
printf("%d\n", Offsetof(struct S, n));
}
这里的思路是从0这个点取地址,然后计算到要求的数的距离。