处理有符号和无符号整数的运算符的提升规则
当处理涉及操作数之间不同符号的二元运算符时,中概述的提升规则C 标准开始发挥作用。这些规则决定了运算的结果类型以及操作数的转换方式。
具体来说,“通常的算术转换”适用于此处(第 5/9 节)。这些转换按降序排列:
- 长双精度(如果存在)
- 双精度
- 浮点
- 积分促销(转换短/整型) /long long 到 int/long/long long)
- 无符号长整型(如果存在)
- 如果 long int 可以表示所有 unsigned int 值,则为 Long,否则为 unsigned long int
- Long(如果存在)
- Unsigned(如果存在)
将这些规则应用于两种场景呈现:
场景1:
int max = std::numeric_limits<int>::max();
unsigned int one = 1;
unsigned int result = max + one;
- max是signed int,1个是unsigned int
- 发生积分提升,导致max as int
- 由于 unsigned int 排名较高,因此结果类型为unsigned int
- 结果: unsigned 溢出到 2147483648
场景 2:
unsigned int us = 42;
int neg = -43;
int result = us + neg;
- us 是 unsigned int, neg已签署int
- 发生整数提升,导致我们为unsigned int,neg为int
- 由于unsigned int排名较高,所以结果类型为unsigned int
- 但是值我们的负数 (-1) 无法用 int
- 表示结果:实现定义的行为,可能返回-1 或取决于平台
以上是C 提升规则如何处理有符号和无符号整数的二元运算?的详细内容。更多信息请关注PHP中文网其他相关文章!