gpt4 book ai didi

c - 宏定义 :' #define my_macro (1 << 16) ' 和 '#define my_macro(1U << 16)' 有什么区别

转载 作者:太空宇宙 更新时间:2023-11-04 06:41:54 24 4
gpt4 key购买 nike

我猜后者明确指示将“1”视为无符号整数。但是,如果有任何前者,那么不良的副作用是什么。我看到这两个都在 linux 内核中使用。那么哪个更准确/更推荐,为什么?

最佳答案

1 << x 有一个问题当您将 1 向左移动足够远时,就会变得很明显。在用二进制补码表示整数的机器上,这会使值突然变为负数。假设 int 32位宽度:

#include <stdio.h>

int
main(int argc, const char** argv)
{
printf("%d\n", (1 << 30));
printf("%d\n", (1 << 31));
printf("%ud\n", (1U << 30));
printf("%ud\n", (1U << 31));
return 0;
}

产量

1073741824
-2147483648
1073741824d
2147483648d

在我的机器上。这在代码的其他部分可能是意想不到的。特别是,由于有符号扩展,反向移位不一定等价:

#include <stdio.h>

int
main(int argc, const char** argv)
{
printf("%d\n", (2 << 29) >> 29);
printf("%d\n", (2 << 30) >> 30);
printf("%u\n", (2U << 29) >> 29);
printf("%u\n", (2U << 30) >> 30);
return 0;
}

产量

2
-2
2
2

注意他在第二个输出行翻转了符号...

关于c - 宏定义 :' #define my_macro (1 << 16) ' 和 '#define my_macro(1U << 16)' 有什么区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6691909/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com