std::div_sat
来自 cppreference.cn
定义于头文件 <numeric> |
||
template< class T > constexpr T div_sat( T x, T y ) noexcept; |
(since C++26) | |
计算 饱和 除法 x / y。如果 T
是有符号整数类型,x 是 T
的最小(最负)值,并且 y == -1,则返回 T
的最大值;否则,返回 x / y。
y 不能为 0,否则行为未定义。如果发生未定义行为,则函数调用不是 核心常量表达式。
此重载仅当 T
是 整数类型 时才参与重载解析,即:signed char、short、int、long、long long、扩展的有符号整数类型或此类类型的无符号版本。特别是,T
不得是(可能带有 cv 限定符的)bool、char、wchar_t、char8_t、char16_t 和 char32_t,因为这些类型不用于算术运算。
目录 |
[编辑] 参数
x, y | - | 整数值 |
[编辑] 返回值
饱和 x / y。
[编辑] 注意
与整数的内置算术运算符不同,整数提升 不适用于 x 和 y 参数。
如果传递了两种不同类型的参数,则调用将无法编译,即相对于 模板参数推导 的行为与 std::min 或 std::max 相同。
大多数现代硬件架构都有效支持 SIMD 向量上的饱和算术,包括 x86 的 SSE2 和 ARM 的 NEON。
特性测试 宏 | 值 | 标准 | 特性 |
---|---|---|---|
__cpp_lib_saturation_arithmetic |
202311L |
(C++26) | 饱和算术 |
[编辑] 可能的实现
namespace detail { template<class T> concept standard_or_extended_integral = std::is_integral_v<T> && !std::is_same_v<std::remove_cv_t<T>, bool> && !std::is_same_v<std::remove_cv_t<T>, char> && !std::is_same_v<std::remove_cv_t<T>, char8_t> && !std::is_same_v<std::remove_cv_t<T>, char16_t> && !std::is_same_v<std::remove_cv_t<T>, char32_t> && !std::is_same_v<std::remove_cv_t<T>, wchar_t>; } // namespace detail template<detail::standard_or_extended_integral T> constexpr T div_sat( T x, T y ) noexcept { if constexpr (std::is_signed_v<T>) if (x == std::numeric_limits<T>::min() && y == -1) return std::numeric_limits<T>::max(); return x / y; } |
[编辑] 示例
可以在 Compiler Explorer 上预览。
运行此代码
[编辑] 参见
(C++26) |
两个整数的饱和加法运算 (函数模板) |
(C++26) |
两个整数的饱和减法运算 (函数模板) |
(C++26) |
两个整数的饱和乘法运算 (函数模板) |
(C++26) |
返回一个钳制到另一个整数类型范围的整数值 (函数模板) |
(C++17) |
将值钳制在一对边界值之间 (函数模板) |
(C++20) |
检查整数值是否在给定整数类型的范围内 (函数模板) |
[静态] |
返回给定非浮点类型的最小有限值,或给定浮点类型的最小正规值 ( std::numeric_limits<T> 的公共静态成员函数) |
[静态] |
返回给定类型的最大有限值 ( std::numeric_limits<T> 的公共静态成员函数) |
[编辑] 外部链接
1. | 饱和算术的无分支实现 — Locklessinc.com, 2012 |
2. | C++ 周刊 - 第 459 集 - C++26 的饱和数学运算 — Youtube.com, 2024-12-16 |