当前位置:  开发笔记 > 编程语言 > 正文

boost :: multiprecision :: uint128_t sizeof是24

如何解决《boost::multiprecision::uint128_tsizeof是24》经验,为你挑选了1个好方法。

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

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

...

qDebug() << sizeof(uint128_t);

产量:24.

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

更新:提升版本是1.61.



1> lcs..:

cpp_int 1.6.1

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

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

推荐阅读
殉情放开那只小兔子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有