百科问答小站 logo
百科问答小站 font logo



C++中 int n = 0ULL - 1; 是 UB 未定义行为吗? 第1页

  

user avatar   Kurenai_Misuzu 网友的相关建议: 
      

首先结论:没有未定义行为, C++20 起保证得到 -1 , C++20 前结果为实现定义,但所有已知实现都得到 C++20 起保证的结果。

0ULL - 1 这个表达式中先进行通常算术转换:两边类型分别为 unsigned long long 与 int ,转换到公共类型 unsigned long long 。然后进行无符号整数的算术运算,这里有模算术,结果是 unsigned long long 类型的最大值。定义中最后是转换到 int 。这一步操作从 C++20 起变为唯一定义:整数值转换到宽度为 W 位的另一整数类型值,结果为目标类型中与源类型对 2^W 同余的唯一值。于是结果即 int 类型的 -1 。

C++20 前结果为实现定义(见后述),而已知实现上均得到与 C++20 规则一致的结果。

C++20 起限制了有符号整数必须用补码表示,并且从范围外的值转换到有符号整数类型必须遵循上述规则(等价于截断二进制表示)。之前这两点是实现定义,但已知的 C++ 实现均遵循这些规则( C 的有例外)。


C++20 中确实有关于 UB 的相关改动:减少了有符号整数左移未定义的情况(可以粗略认为变得与无符号整数左移“等价”了)。不过这就与本问题无关了。


user avatar   pansz 网友的相关建议: 
      

低情商:是的,已经结束了。

高情商:diy的时代暂停了,只不过我们暂时不知道重新开放的期限。




  

相关话题

  C++中 unsigned t = 2147483647 + 1 + 1; 是 UB 还是 ID? 
  为什么 Go 和 Rust 常提供静态编译好的 Linux 程序,而 C 不行? 
  vector 使用 emplace_back 会调用复制构造函数吗? 
  C/C++中的数组为什么必须定义之后在一行内立刻赋值,而不能定义数组之后换一行再赋值? 
  C/C++ 标准库为什么不支持直接删除一个文件中的部分内容? 
  Matlab/NumPy/C++Eigen 速度差距为什么很大? 
  为什么 C++ 中一个类的成员类型不能是该类本身,而 C# 中就可以? 
  大一新生入学半个月,有比赛需要一个月造出红外循迹智能车,会C语言和c++,要怎么开始入门? 
  学C#需要学好C++么? 
  c++怎么在1到n这些数中随机产生k(k<n)个?当然,k个数互不相等。有什么比较好的写法吗? 

前一个讨论
程序在编译的时候,会转换成汇编,然后是机器指令,那么运行的时候,操作系统充当什么呢?
下一个讨论
男子收养猫后向原主人索要裸照和钱,遭拒后虐杀猫发给原主人,被拘时已杀 6 猫,男子将承担哪些责任?





© 2025-05-14 - tinynew.org. All Rights Reserved.
© 2025-05-14 - tinynew.org. 保留所有权利