Namespaces
Variants

std:: div_sat

From cppreference.net
Saturation arithmetic
Functions
(C++26)
(C++26)
(C++26)
div_sat
(C++26)
Definido en el encabezado <numeric>
template < class T >
constexpr T div_sat ( T x, T y ) noexcept ;
(desde C++26)

Calcula la división con saturación x / y . Si T es un tipo entero con signo, x es el valor más pequeño (más negativo) de T , y y == - 1 , devuelve el valor máximo de T ; de lo contrario, devuelve x / y .

y no debe ser 0 , de lo contrario el comportamiento es indefinido. La llamada a la función no es una expresión constante principal si ocurre un comportamiento indefinido.

Esta sobrecarga participa en la resolución de sobrecarga solo si T es un tipo entero , es decir: signed char , short , int , long , long long , un tipo entero con signo extendido, o una versión sin signo de dichos tipos. En particular, T no debe ser (posiblemente calificado con cv) bool , char , wchar_t , char8_t , char16_t , y char32_t , ya que estos tipos no están destinados a operaciones aritméticas.

Contenidos

Parámetros

x, y - valores enteros

Valor de retorno

Saturado x / y .

Notas

A diferencia de los operadores aritméticos incorporados en enteros, la integral promotion no se aplica a los argumentos x y y .

Si se pasan dos argumentos de tipo diferente, la llamada falla al compilar, es decir, el comportamiento relativo a template argument deduction es el mismo que para std::min o std::max .

La mayoría de las arquitecturas de hardware modernas tienen soporte eficiente para aritmética de saturación en vectores SIMD , incluyendo SSE2 para x86 y NEON para ARM .

Macro de prueba de características Valor Estándar Característica
__cpp_lib_saturation_arithmetic 202311L (C++26) Aritmética de saturación

Implementación posible

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;
}

Ejemplo

Se puede previsualizar en Compiler Explorer .

#include <climits>
#include <numeric>
static_assert
(""
    && (std::div_sat<int>(6, 3) == 2) // no saturado
    && (std::div_sat<int>(INT_MIN, -1) == INT_MAX) // saturado
    && (std::div_sat<unsigned>(6, 3) == 2) // no saturado
);
int main() {}

Véase también

(C++26)
operación de suma con saturación en dos enteros
(plantilla de función)
(C++26)
operación de resta con saturación en dos enteros
(plantilla de función)
(C++26)
operación de multiplicación con saturación en dos enteros
(plantilla de función)
devuelve un valor entero limitado al rango de otro tipo entero
(plantilla de función)
(C++17)
limita un valor entre un par de valores límite
(plantilla de función)
(C++20)
comprueba si un valor entero está en el rango de un tipo entero dado
(plantilla de función)
[static]
devuelve el valor finito más pequeño del tipo no flotante dado, o el valor normal positivo más pequeño del tipo flotante dado
(función miembro estática pública de std::numeric_limits<T> )
[static]
devuelve el valor finito más grande del tipo dado
(función miembro estática pública de std::numeric_limits<T> )

Enlaces externos

1. Una implementación sin bifurcaciones de aritmética de saturación — Locklessinc.com, 2012
2. C++ Weekly - Ep 459 - Operaciones Matemáticas de Saturación de C++26 — Youtube.com, 2024-12-16