[英]Why doesn't uint128_t have bit shift overloads for uint128_t?
当两个操作数均为uint128_t
时, boost::multiprecision::uint128_t
似乎对左/右移位运算符没有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
或类似形式)。
解决方法:
#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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.