std::abs(float), std::fabs, std::fabsf, std::fabsl
De cppreference.com
Definido en el archivo de encabezado <cmath>
|
||
Definido en el archivo de encabezado <cstdlib>
|
||
float abs( float arg ); |
(1) | (constexpr since C++23) |
double abs( double arg ); |
(2) | (constexpr since C++23) |
long double abs( long double arg ); |
(3) | (constexpr since C++23) |
Definido en el archivo de encabezado <cmath>
|
||
float fabs ( float arg ); |
(4) | (constexpr since C++23) |
float fabsf( float arg ); |
(5) | (desde C++11) (constexpr since C++23) |
double fabs ( double arg ); |
(6) | (constexpr since C++23) |
long double fabs ( long double arg ); |
(7) | (constexpr since C++23) |
long double fabsl( long double arg ); |
(8) | (desde C++11) (constexpr since C++23) |
double fabs ( TipoEntero arg ); |
(9) | (desde C++11) (constexpr since C++23) |
1-8) Calcula el valor absoluto de un valor de punto flotante
arg
.9) Un conjunto de sobrecargas o una plantilla de función que acepta un argumento de cualquier tipo entero. Equivalente a (6) (el argumento se convierte a double).
Para argumentos de tipo entero, las sobrecargas con enteros de std::abs
son probablemente mejores coincidencias. Si std::abs
se llama con un argumento de tipo entero sin signo que no puede convertirse a int por la promoción de enteros, el programa está mal formado.
Contenido |
[editar] Parámetros
arg | - | Valor de un tipo de punto flotante o tipo entero. |
[editar] Valor de retorno
Si tuvo éxito, devuelve el valor absoluto de arg
(|arg|
). El valor devuelto es exacto y no depende de ningún modo de redondeo.
[editar] Manejo de errores
Esta función no está sujeta a ninguna de las condiciones de error especificadas en math_errhandling.
Si la implementación admite la aritmética de punto flotante de la IEEE (IEC 60559):
- Si el argumento +0 o -0, se devuelve +0 o -0, respectivamente.
- Si el argumento +∞ o -∞, se devuelve +∞.
- Si el argumento es NaN, se devuelve NaN.
[editar] Ejemplo
Ejecuta este código
#include <iostream> #include <cmath> int main() { std::cout << "abs(+3.0) = " << std::abs(+3.0) << '\n' << "abs(-3.0) = " << std::abs(-3.0) << '\n'; // valores especiales std::cout << "abs(-0.0) = " << std::abs(-0.0) << '\n' << "abs(-Inf) = " << std::abs(-INFINITY) << '\n' << "abs(-NaN) = " << std::abs(-NAN) << '\n'; }
Posible salida:
abs(+3.0) = 3 abs(-3.0) = 3 abs(-0.0) = 0 abs(-Inf) = inf abs(-NaN) = nan
[editar] Informes defectos
Los siguientes informes de defectos de cambio de comportamiento se aplicaron de manera retroactiva a los estándares de C++ publicados anteriormente.
ID | Aplicado a | Comportamiento según lo publicado | Comportamiento correcto |
---|---|---|---|
LWG 2192 | C++98 | Las sobrecargas de std::abs estaban declaradasde manera inconsistente en dos encabezados. |
Se declaran estas sobrecargas en ambos encabezados. |
LWG 2735 | C++11 | Se requería erróneamente que std::abs tuviera sobrecargaspara tipos enteros que devuelven double |
Se eliminó el requisito. |
[editar] Véase también
(C++11) |
Calcula el valor absoluto de un valor entero (|x|) (función) |
(C++11)(C++11)(C++11) |
Copia el signo de un valor de punto flotante. (función) |
(C++11) |
Comprueba si el número dado es negativo (función) |
Devuelve la magnitud de un número complejo. (plantilla de función) | |
se aplica la std::abs función a cada elemento de valarray Original: applies the function std::abs to each element of valarray The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (plantilla de función) | |
Documentación de C para fabs
|