【C/C++】宏定义标志位使用到 (1U<<0)是为什么?

最近开发过程中,遇到一些不同平台的编译器问题

宏定义标志位使用到 (1U<<0)就是出于为了应对不同的编译器。

也就是说:1U<<0 与 1<<0 有什么区别? 答案是:移植性更强。

在实际开发中,不同的编译器都将会把有符号的左移视为无符号左移,会出现问题。

而且,若外部变量 int Count = 0 , 是未签名的,若将其与已签名的 1 << 0 进行比较,则会出现编译器告警,会丢失精准度,甚至报错,显然,我们使用 1U<<0,则会消除这样的隐患,而且也不用担心左移 31或 63位会发生什么问题。

相关推荐
天赐学c语言14 分钟前
1.20 - x的平方根 && vector的扩容机制以及删除元素是否会释放内存
c++·算法·leecode
未若君雅裁23 分钟前
SpringAI基础入门
java·spring boot·ai
CC.GG30 分钟前
【C++】用哈希表封装myunordered_map和 myunordered_set
java·c++·散列表
a努力。1 小时前
字节Java面试被问:TCP的BBR拥塞控制算法原理
java·开发语言·python·tcp/ip·elasticsearch·面试·职场和发展
jiaguangqingpanda1 小时前
Day24-20260120
java·开发语言·数据结构
一个龙的传说1 小时前
xshell下载
java
C雨后彩虹2 小时前
羊、狼、农夫过河
java·数据结构·算法·华为·面试
xiaoye-duck2 小时前
C++ string 类使用超全攻略(上):创建、遍历及容量操作深度解析
c++·stl
java资料站2 小时前
SpringAI+DeepSeek大模型应用开发实战
java
csdn_aspnet2 小时前
C++跨平台开发,分享一些用C++实现多平台兼容的工程难题与解决方案
c++