std::sub_sat
来自 cppreference.com
定义在头文件 <numeric> 中 |
||
template< class T > constexpr T sub_sat( T x, T y ) noexcept; |
(自 C++26 起) | |
计算饱和减法 x - y。此操作(与整数的内置算术运算不同)的行为就像一个具有无限范围的数学运算。令q
表示此操作的结果。返回值
-
q
,如果q
可以表示为类型T
的值。否则, - 类型
T
的最大或最小值,以更接近q
的值为准。
此重载仅在 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。
功能测试 宏 | 值 | Std | 功能 |
---|---|---|---|
__cpp_lib_saturation_arithmetic |
202311L | (C++26) | 饱和运算 |
[编辑] 可能的实现
参见 libstdc++ (gcc).
[编辑] 示例
可以在 编译器资源管理器 上预览。
运行此代码
#include <climits> #include <numeric> static_assert ("" && (std::sub_sat<int>(INT_MIN + 4, 3) == INT_MIN + 1) // not saturated && (std::sub_sat<int>(INT_MIN + 4, 5) == INT_MIN) // saturated && (std::sub_sat<int>(INT_MAX - 4, -3) == INT_MAX - 1) // not saturated && (std::sub_sat<int>(INT_MAX - 4, -5) == INT_MAX) // saturated && (std::sub_sat<unsigned>(4, 3) == 1) // not saturated && (std::sub_sat<unsigned>(4, 5) == 0) // saturated ); int main() {}
[编辑] 另请参阅
(C++26) |
两个整数的饱和加法运算 (函数模板) |
(C++26) |
两个整数的饱和乘法运算 (函数模板) |
(C++26) |
两个整数的饱和除法运算 (函数模板) |
(C++26) |
返回一个限制在另一个整数类型范围内的整数值 (函数模板) |
(C++17) |
将值夹紧在两个边界值之间 (函数模板) |
(C++20) |
检查整数值是否在给定整数类型的范围内 (函数模板) |
[静态] |
返回给定类型的最小有限值 ( std::numeric_limits<T> 的公共静态成员函数) |
[静态] |
返回给定类型的最大有限值 ( std::numeric_limits<T> 的公共静态成员函数) |
[编辑] 外部链接
1. | 饱和算术的无分支实现 — Locklessinc.com, 2012 |