C++STL---<limits>

C++ <limits> 头文件:

<limits> 头文件是 C++ 标准库中用于获取各种数据类型的数值范围、精度等信息的工具。它通过模板类 std::numeric_limits 提供了对基本数据类型(如 intfloatdouble 等)的详细属性查询功能。通过 std::numeric_limits<T>,开发者可以获取类型 T 的最小值、最大值、是否为有符号类型、是否支持无穷大、是否为整数类型等信息。例如,std::numeric_limits<int>::max() 返回 int 类型的最大值,std::numeric_limits<double>::epsilon() 返回 double 类型的机器精度。该头文件在需要处理数值边界或进行跨平台开发时非常有用,能够帮助开发者编写更健壮和可移植的代码。


1. numeric_limits<T> 概述

核心功能

  1. 类型极值查询:获取类型的最大值(max())和最小值(min()lowest())。
  2. 浮点特性检测:支持无穷大(infinity())、非数值(quiet_NaN())等特殊值的操作。
  3. 底层属性分析:判断类型是否带符号(is_signed)、是否为整数类型(is_integer)等。
  4. 平台适配支持:检测溢出是否取模(is_modulo)、浮点舍入模式(round_style)等。

头文件与基本用法

#include <limits>
using namespace std;int main() {cout << "int 最大值: " << numeric_limits<int>::max() << endl;  // 输出 2147483647return 0;
}

2. 核心成员函数

2.1 极值查询

min()max()
  • 功能:获取类型的最小值和最大值。
  • 适用类型:所有算术类型(整数、浮点、字符等)。
  • 示例
    cout << "int 最小值: " << numeric_limits<int>::min() << endl;  // -2147483648
    cout << "float 最大值: " << numeric_limits<float>::max() << endl;  // 3.40282e+38
    
lowest()(C++11 新增)
  • 功能:返回类型的最小有限值(对浮点类型更准确)。
  • 示例
    cout << "float 最小有限值: " << numeric_limits<float>::lowest() << endl;  // -3.40282e+38
    

2.2 浮点类型专用

epsilon()
  • 功能:返回浮点类型的精度(1 与最小可表示大于 1 的值的差)。
  • 示例
    cout << "double 精度: " << numeric_limits<double>::epsilon() << endl;  // 2.22045e-16
    
infinity()quiet_NaN()
  • 功能
    • infinity():获取正无穷大(需 has_infinitytrue)。
    • quiet_NaN():获取非信号型非数值(NaN)。
  • 示例
    if (numeric_limits<float>::has_infinity) {float inf = numeric_limits<float>::infinity();cout << "正无穷大: " << inf << endl;  // 输出 inf
    }
    float nan = numeric_limits<float>::quiet_NaN();
    

2.3 类型属性检测

成员函数/常量功能描述示例(int 类型)
digits类型的有效位数(不含符号位)numeric_limits<char>::digits → 7
is_signed类型是否带符号numeric_limits<unsigned>::is_signedfalse
is_integer是否为整数类型numeric_limits<double>::is_integerfalse

3. 底层特性与平台适配

3.1 溢出行为检测

is_modulo
  • 功能:检测类型溢出时是否按模运算(通常无符号类型为 true)。
  • 应用场景:安全数值运算设计。
  • 示例
    if (numeric_limits<int>::is_modulo) {cout << "int 溢出会回绕" << endl;
    } else {cout << "int 溢出行为未定义" << endl;  // 典型输出
    }
    

3.2 浮点标准合规性

is_iec559
  • 功能:检测浮点类型是否符合 IEEE 754 标准。
  • 示例
    if (numeric_limits<float>::is_iec559) {cout << "float 符合 IEEE 754" << endl;  // 常见平台为 true
    }
    
round_style
  • 功能:返回浮点舍入模式(如 round_to_nearest)。
  • 示例
    auto style = numeric_limits<double>::round_style;
    if (style == round_to_nearest) {cout << "使用四舍五入模式" << endl;
    }
    

4. 实际应用场景

4.1 防止数值溢出

template<typename T>
T safe_add(T a, T b) {if ((b > 0) && (a > numeric_limits<T>::max() - b)) {throw overflow_error("加法溢出");}return a + b;
}

4.2 浮点数判等(考虑精度误差)

bool almost_equal(double x, double y) {return abs(x - y) < numeric_limits<double>::epsilon() * max(abs(x), abs(y));
}

4.3 动态类型特性检查

template<typename T>
void print_numeric_info() {if constexpr (numeric_limits<T>::is_signed) {cout << "类型范围: [" << numeric_limits<T>::min() << ", " << numeric_limits<T>::max() << "]\n";} else {cout << "类型范围: [0, " << numeric_limits<T>::max() << "]\n";}
}

5. 与 C 风格宏的对比

优势

  1. 类型安全:避免 INT_MAX 误用于 long 等类型错误。
  2. 泛型友好:模板代码中可统一接口,无需类型判断。
  3. 扩展性:支持用户自定义类型的特化。

对比示例

// C 风格
int max_int = INT_MAX;  // 需要包含 <climits>// C++ 风格
int max_int = numeric_limits<int>::max();  // 类型明确

6. 扩展:自定义类型特化

用户可为自定义类型特化 numeric_limits 以支持标准查询接口。

示例

class Decimal {int value;  // 以整型存储固定小数
public:Decimal(int val) : value(val) {}
};namespace std {
template<>
class numeric_limits<Decimal> {
public:static constexpr bool is_specialized = true;static Decimal max() { return Decimal(9999); }static Decimal min() { return Decimal(-9999); }// 其他必要成员定义...
};
} // namespace std

7. 注意事项

  1. 非算术类型:默认未特化的类或字符串类型无法使用 numeric_limits
  2. 编译时常量:所有成员均为 constexpr,可用于模板元编程。
  3. C++11 扩展:优先使用 lowest() 而非 min() 获取浮点类型的最小有限值。
  4. 平台差异is_modulo 等属性可能因编译器和硬件不同而变化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/72370.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯自我复习打卡

总复习&#xff0c;打卡1. 一。排序 1。选段排序 太可恶了&#xff0c;直接全排输出&#xff0c;一个测试点都没过。 AC 首先&#xff0c;这个【l,r】区间一定要包含p,或者q&#xff0c;pq一个都不包含的&#xff0c;[l,r]区间无论怎么变&#xff0c;都对ans没有影响。 其次&…

Flutter_学习记录_实现列表上拉加载更多的功能

可以用ScrollController组件来实现这样列表上拉加载更多的功能: 1. 定义变量 在StatefulWidget 的组件内&#xff0c;添加三个属性&#xff1a; // 滚动视图的控制器final ScrollController _scrollController ScrollController();// 是否已显示了上拉加载中bool _isShowM…

【Linux】【网络】不同子网下的客户端和服务器通信其它方式

【Linux】【网络】不同子网下的客户端和服务器通信其它方式 那么&#xff0c;在 NAT 环境下&#xff0c;应该如何让内网设备做为服务器&#xff0c;使内网设备被外部连接&#xff1f; 1 多拨 部分运营商&#xff0c;支持在多个设备上&#xff0c;通过 PPPoE 登录同一个宽带账…

《Python百练成仙》31-40章(不定时更新)

第卅一章 函数结丹def开紫府 罗酆山的鬼门关吞吐着猩红的变量阴风&#xff0c;每个风眼都涌动着作用域混乱的灵力乱流。叶军手握薛香遗留的丹田玉简&#xff0c;玉简表面浮现出残缺的函数符文&#xff1a; def 凝聚金丹(灵气):道基 灵气 * 0.618print(金丹品质) # 作用域外变…

六十天前端强化训练之第一天到第七天——综合案例:响应式个人博客项目

欢迎来到编程星辰海的博客讲解 目录 前言回顾 HTML5与CSS3基础 一、知识讲解 1. 项目架构设计&#xff08;语义化HTML&#xff09; 2. 响应式布局系统&#xff08;Flex Grid&#xff09; 3. 样式优先级与组件化设计 4. 完整响应式工作流 二、核心代码示例 完整HTML结…

测试的BUG分析

在了解BUG之前,我们要先了解软件测试的生命周期,因为大多数BUG都是在软件测试的过程中被发现的 软件测试的生命周期 在了解 软件测试的生命周期 之前,我们要先了解 软件的生命周期 ,虽然他们之间只差了两个字,但是差距还是很大的 首先是 软件生命周期 ,这个是站在 软件 的角…

【洛谷贪心算法题】P1094纪念品分组

该题运用贪心算法&#xff0c;核心思想是在每次分组时&#xff0c;尽可能让价格较小和较大的纪念品组合在一起&#xff0c;以达到最少分组的目的。 【算法思路】 输入处理&#xff1a;首先读取纪念品的数量n和价格上限w&#xff0c;然后依次读取每件纪念品的价格&#xff0c;…

[STM32]从零开始的STM32 BSRR、BRR、ODR寄存器讲解

一、前言 学习STM32一阵子以后&#xff0c;相信大家对STM32 GPIO的控制也有一定的了解了。之前在STM32 LED的教程中也教了大家如何使用寄存器以及库函数控制STM32的引脚从而点亮一个LED&#xff0c;之前的寄存器只是作为一个引入&#xff0c;并没有深层次的讲解&#xff0c;在教…

SQL分组问题

下列为电商公司用户访问时间数据 统计某个用户连续的访问记录&#xff0c;如果时间间隔小于60s&#xff0c;就分为一组 id ts 1001 17523641234 1001 17523641256 1002 17523641278 1001 17523641334 1002 17523641434 1001 17523641534 1001 17523641544 1002 17523…

3月2日 C++日常习题测试一答案

C测试题答案与讲解 一、填空题答案及讲解 答案&#xff1a;const 讲解&#xff1a;在 C 中&#xff0c;const关键字用于定义常量&#xff0c;一旦定义&#xff0c;其值不能被修改。例如const int num 10;&#xff0c;这里的num就是一个常量。 答案&#xff1a;3 讲解&…

2W8000字 LLM架构文章阅读指北

❝ 大模型架构专栏已经更新了30多篇文章。完整的专栏内容欢迎订阅&#xff1a; LLM 架构专栏 1、LLM大模型架构专栏|| 从NLP基础谈起 2、 LLM大模型架构专栏|| 自然语言处理&#xff08;NLP&#xff09;之建模 3、 LLM大模型架构之词嵌入&#xff08;Part1&#xff09; 3、 LLM…

SP导入智能材质球

智能材质球路径 ...\Adobe Substance 3D Painter\resources\starter_assets\smart-materials 放入之后就会自动刷新

网络原理----TCP/IP(3)

核心机制七----延时应答 默认情况下&#xff0c;接收方都是在收到数据报的第一时间&#xff0c;就返回ack&#xff0c;但是可以通过延时返回ack的方式来提高效率&#xff0c;理论上不是100%提高效率&#xff0c;但还是有一定帮助的。 因为如果接收数据的主机⽴刻返回ACK应答,…

MacBook Pro使用FFmpeg捕获摄像头与麦克风推流音视频

FFmpeg查看macos系统音视频设备列表 ffmpeg -f avfoundation -list_devices true -i "" 使用摄像头及麦克风同时推送音频及视频流: ffmpeg -f avfoundation -pixel_format yuyv422 -framerate 30 -i "0:1" -c:v libx264 -preset ultrafast -b:v 1000k -…

部署Joplin私有云服务器postgres版-docker compose

我曾经使用过一段时间 Joplin&#xff0c;官方版本是收费的&#xff0c;而我更倾向于将数据掌握在自己手中。因此&#xff0c;在多次权衡后&#xff0c;我决定自己搭建 Joplin 服务器并进行尝试。 个人搭建的版本与数据库直连&#xff0c;下面是使用 Docker Compose 配置数据库…

SQL的select语句完整的执行顺序

SQL的SELECT语句的执行顺序可以用"做菜流程"来类比理解。虽然我们写SQL时按SELECT…FROM…WHERE…顺序写&#xff0c;但数据库执行顺序完全不同。以下是通俗易懂的讲解&#xff08;附流程图和示例&#xff09;&#xff1a; &#x1f527; 执行顺序流程图&#xff1a…

Spring Cloud LoadBalancer详解

一、介绍 Spring Cloud LoadBalancer是Spring Cloud官方自己提供的客户端负载均衡器,抽象和实现,用来替代Ribbon(已经停更), 二、Ribbon和Loadbalance 对比 组件组件提供的负载策略支持负载的客户端Ribbon随机 RandomRule轮询 RoundRobinRule 重试 RetryRule最低并发 Bes…

ubuntu中ollama设置记录

自己同一台电脑主机安装3080和3090显卡&#xff0c;测试发现ollama只默认跑在3090上&#xff1b;故查看一下设置&#xff0c;成功也把3080也运行起来了。 原因如下&#xff1a; 开始设置记录&#xff1a; Environment Variables: OLLAMA_DEBUG 作用&#xff1a;显示额外的调试…

RabbitMQ系列(四)基本概念之Exchange

在 RabbitMQ 中&#xff0c;Exchange&#xff08;交换机&#xff09; 是消息路由的核心组件&#xff0c;负责根据规则将生产者发送的消息分发到对应的队列&#xff08;Queue&#xff09;中。以下是其核心功能与分类的详细说明&#xff1a; 一、Exchange 的核心作用 消息路由枢…

有没有什么免费的AI工具可以帮忙做简单的ppt?

互联网各领域资料分享专区(不定期更新): Sheet 正文 1. 博思AIPPT 特点:专为中文用户设计,支持文本/文件导入生成PPT,内置海量模板和智能排版功能,涵盖商务、教育等多种场景。可一键优化布局、配色,并集成AI绘图功能(文生图/图生图)。适用场景:职场汇报、教育培训、商…