boost :: multiprecision :: uint128_t sizeof是24

时间:2017-01-26 14:55:20

标签: c++ boost sizeof boost-multiprecision

基础数学(128/8 = 16)说话方式不同。我有点失望并希望得到一些答案 - 因为从我习惯的那种情况来看,这种符号(type_num_of_bytes_t)不仅描述了你可以放入变量的数据量,还有跨平台固定变量大小,后者是IMHO甚至更重要。我做错了什么?

#include "boost/multiprecision/cpp_int.hpp"
using boost::multiprecision::uint128_t;

...

qDebug() << sizeof(uint128_t);

输出:24。

我正在使用标准的x86 / 64架构CPU,在Windows上使用vs2013进行编译。

更新:提升版本是1.61。

1 个答案:

答案 0 :(得分:9)

cpp_int 1.6.1

  

当以固定精度使用时,此类型的大小总是比您对N位整数所期望的大一个机器字:额外的单词存储符号和多少机器实际上正在使用整数中的单词。后者是对较大固定精度整数的优化,因此1024位整数具有与128位整数几乎相同的性能特征,而不是加法慢4倍和乘法慢16倍(假设涉及的值)总是适合128位)。通常,这意味着您可以使用足够宽的整数类型来处理“最坏情况”,只有很小的性能下降,即使大多数情况下算术实际上可以用较窄的类型完成。

额外的机器字(在x86/64 8字节上)使得大小为24而不是预期的16。