为什么uint128_t没有位移位过载uint128_t?
Why doesn't uint128_t have bit shift overloads for uint128_t?
当两个操作数都是uint128_t
时,boost::multiprecision::uint128_t
的左/右移位操作符似乎没有过载:
uint128_t operator<<(uint128_t, uint128_t); // Missing
uint128_t operator>>(uint128_t, uint128_t); // Also Missing
示例代码:
#include <boost/multiprecision/cpp_int.hpp>
int main() {
using uint128_t = boost::multiprecision::uint128_t;
uint128_t number = 100;
uint128_t ten = 10;
auto leftShift = number << ten; // fail
auto rightShift = number >> ten; // fail
return 0;
}
这是一个演示。
错误消息很长,所以下面是左移操作符的(修改过的)第一条消息:
prog.cpp:8:26: error: no match for 'operator<<' (operand types
are 'uint128_t {aka boost_template_typedef_for_uint128_t}'
and 'uint128_t {aka boost_template_typedef_for_uint128_t}')
auto leftShift = number << ten; // fail
您可以查看演示以获得完整的错误消息。
为什么会这样?我看不出他们不被实现的理由,因为unsigned a = 100u << 2u;
对于相同的类型工作得很好。
这是因为向左移动这么多位很少有用。它定义了浮点表示(使用cpp_dec_float
或类似的)。
这里有一个解决方法:
Live On Coliru
#include <boost/multiprecision/integer.hpp>
#include <boost/multiprecision/cpp_int.hpp>
#include <iostream>
int main() {
boost::multiprecision::uint128_t v("1"), u("20");
v = v << u.convert_to<size_t>();
std::cout << v;
}
打印
1048576
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?