繁体   English   中英

为什么uint128_t没有uint128_t的移位超载?

[英]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或类似形式)。

解决方法:

生活在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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM