c++|表达最值的更好方法|clamp

clamp

C++17引入的 std::clamp (头文件 <algorithm> ),用于将值限定在 min, max 区间内,超界则返回边界值,语法: clamp(val, min_val, max_val) ,需满足 min_val ≤ max_val ,是线程安全的constexpr函数

线程安全的constexpr函数

C++17+支持,编译期可计算(constexpr)且多线程并发调用时,无数据竞争、结果一致(无共享可变状态)的函数。

C++98引入的 std::numeric_limits 比传统宏定义,在类型安全、可移植性、功能和代码可读性维护性等方面都更优

表达最大值、最小值,传统方法是 MAX_INT64 这样的宏。

更好的方法是用下面这种:

  • std::numeric_limits<uint8_t>::max()

  • std::numeric_limits<int64_t>::max()

  • std::numeric_limits<int>::max()

细节

std::numeric_limits 是 C++ 标准库中的一个模板类,定义在 <limits> 头文件中。它用于查询算术类型(如整数、浮点数)的属性,例如最大值、最小值、精度等。通过特化不同数据类型,可以获取该类型的编译时常量信息。

特化

std::numeric_limits 需针对具体类型特化。标准库已内置对基本类型的特化(如 int 、 float ),用户也可为自定义类型实现特化。

// 内置类型的特化由标准库提供

static_assert(std::numeric_limits<

// 自定义类型的特化示例(需实现相应成员)

template <>

class std::numeric_limits<MyType>

static constexpr bool is_speci

// 其他必要成员...如 min(), max()

};

注意事项

非算术类型(如类或指针)的特化需手动实现,否则 is_specialized 默认为 false 。

浮点类型的 min() 和 lowest() 区别: min() 返回最小正规范化值, lowest() 返回最小有限值(可能为负数)。

编译时常量:所有成员均为 static constexpr ,可在编译期使用。

此模板类广泛用于数值计算、类型安全检查和泛型编程中,是 C++ 类型系统的重要工具之一。

相关推荐
郝学胜_神的一滴1 天前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
见过夏天2 天前
C++ 基础入门完全指南
c++
用户805533698033 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK4 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境4 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境4 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
郝学胜_神的一滴5 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
卷无止境7 天前
C++ 的Eigen 库全解析
c++
卷无止境7 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴7 天前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake