命名空间
变体
操作

std::sub_sat

来自 cppreference.com
< cpp‎ | numeric
定义在头文件 <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 charshortintlonglong long、扩展的带符号整数类型或这些类型的无符号版本。特别地,T 不能是(可能带有 cv 限定的)boolcharwchar_tchar8_tchar16_tchar32_t,因为这些类型并非用于算术运算。

内容

[编辑] 参数

x, y - 整数值

[编辑] 返回值

饱和的 x - y.

[编辑] 注释

与整数的内置算术运算符不同,整数提升不适用于 xy 参数。

如果传递了两个不同类型的参数,则调用无法编译,即相对于模板参数推导的行为与 std::minstd::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++17)
将值夹紧在两个边界值之间
(函数模板) [编辑]
(C++20)
检查整数值是否在给定整数类型的范围内
(函数模板) [编辑]
[静态]
返回给定类型的最小有限值
(std::numeric_limits<T> 的公共静态成员函数) [编辑]
[静态]
返回给定类型的最大有限值
(std::numeric_limits<T> 的公共静态成员函数) [编辑]

[编辑] 外部链接

1.  饱和算术的无分支实现 — Locklessinc.com, 2012