static_assert签名的右移具有两个补码行为是否合法?
Is it legal to static_assert that signed shift right has two's-complement behavior?
在C11、C++11和C++14中执行以下操作合法吗?
static_assert(((-4) >> 1) == -2, "my code assumes sign-extending right shift");
或C等价物:
_Static_assert(((-4) >> 1) == -2, "my code assumes sign-extending right shift");
我不知道常量表达式是否可以使用上面的实现定义的操作的规则。
我知道,无论机器类型如何,负数的有符号左移都是未定义的。
是。C++11标准在[expr.shift]/3:中说
E1 >> E2
的值是E1
右移的E2
比特位置。如果E1
具有无符号类型,或者如果E1
具有有符号类型和非负数值,结果的值是E1/2^E2
如果E1具有带符号类型和负值结果值是实现定义的
在[expr.const]/2中,没有任何地方说这样的移位,或者通常具有实现定义值的表达式不是常量表达式。因此,您将获得一个常量表达式,该表达式具有实现定义的值。
这是合法的,因为它不会导致未定义的行为。
负值右移的行为是实现定义的。C和C++标准并不保证它是算术的或逻辑的;尽管据我所知,从来没有一个CPU不选择其中一个。
相关文章:
- 如何在C++中从两个单独的for循环中添加两个数组
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- 如何返回一个类的两个对象相加的结果
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 如何将两个不同矢量的同一位置的两个元素组合在一起
- 两个字符串在 c++ 中不相等
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 两个文件使用彼此的功能-如何解决
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 如何确保在使用基于布尔值的两个方法之一调用方法时避免分支预测错误
- 停止cmake target_link_libraries将插件中静态库的两个对象文件链接到静态库本身
- 将fold表达式与std::一起用于两个元组
- 如何在C++中比较两个char数组
- 给定两个偶数,求出它们之间所有偶数的平方和
- 比较两个大小不等的映射c++
- 检查两个图是否为补码的功能
- 十进制到二进制,有两个补码
- static_assert签名的右移具有两个补码行为是否合法?
- 在C++中检测一个或两个的补码架构?