boost之multiprecision
multiprecision
boost中提供的高精度库,支持高精度整型,浮点型等。并且提供统一的接口模板,只需要指定对应的后端类型即可实现对应类型的高精度计算:
boost::multiprecision::number<XX_backend>
cpp_int_backend
提供高精度整型后端类型,需引入头文件#include <boost/multiprecision/cpp_int.hpp>
:
template <unsigned MinBits = 0,
unsigned MaxBits = 0,
cpp_integer_type SignType = signed_magnitude,
cpp_int_check_type Checked = unchecked,
class Allocator = std::allocator<limb_type> >
class cpp_int_backend;
- MinBits:底层整型占用的最少位宽
- MaxBits:底层整型占用的最大位宽
- SignType:有符号整型还是无符号整型(任意精度的整型只能为signed!)
- Checked:当发生数值溢出,从字符串转换失败,对负数进行位运算是否抛出异常
- Allocator:内存分配器,当MinBits==MaxBits时,定义为void,表示不需要动态内存分配
cpp_int中无符号型用二进制补码表示,有符号型用原码表示,并且额外用一位来表示符号;不允许任意精度的无符号整型也是因为二进制补码表示需要基于定长的精度。
cpp_int使用示例
有符号数为原码表示,并且额外用一个位表示符号:
int main() {
std::cout << "uint128 max: " << std::numeric_limits<boost::multiprecision::uint128_t>::max() << std::endl;
std::cout << "int128 max: " << std::numeric_limits<boost::multiprecision::int128_t>::max() << std::endl;
std::cout << "int128 min: " << std::numeric_limits<boost::multiprecision::int128_t>::min() << std::endl;
return 0;
}
当有符号数转换为无符号数,先是按位截断,再对无符号数的二进制补码求负数:
int main() {
auto s = std::numeric_limits<boost::multiprecision::int128_t>::min();
auto u = (boost::multiprecision::uint128_t)s;
std::cout << "s: " << s << std::endl;
std::cout << "u: " << u << std::endl;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)