std:: div_sat
|
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 .
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) |
|
(C++26)
|
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 |