abs
, labs
, llabs
_abs64
Calcola il valore assoluto dell'argomento.
Sintassi
int abs( int n );
long labs( long n );
long long llabs( long long n );
__int64 _abs64( __int64 n );
long abs( long n ); // C++ only
long long abs( long long n ); // C++ only
double abs( double n ); // C++ only
long double abs( long double n ); // C++ only
float abs( float n ); // C++ only
Parametri
n
Valore numerico.
Valore restituito
Le abs
funzioni , llabs
labs
, e _abs64
restituiscono il valore assoluto del parametro n
. Non viene restituito alcun errore.
Osservazioni:
Poiché C++ consente l'overload, è possibile chiamare gli overload di abs
che accettano e restituiscono valori long
, long long
, float
, double
e long double
. Questi overload sono definiti nell'intestazione <cmath>
. In un programma C, abs
accetta sempre e restituisce un oggetto int
.
Specifico di Microsoft: l'intervallo di interi negativi rappresentabili in qualsiasi tipo integrale è maggiore dell'intervallo di numeri interi positivi rappresentabili in tale tipo. È quindi possibile fornire un argomento a queste funzioni che non possono essere convertite. Se il valore assoluto dell'argomento non può essere rappresentato dal tipo restituito, le abs
funzioni restituiscono il valore dell'argomento invariato. In particolare, abs(INT_MIN)
restituisce INT_MIN
, labs(LONG_MIN)
restituisce LONG_MIN
, llabs(LLONG_MIN)
restituisce LLONG_MIN
e _abs64(_I64_MIN)
restituisce _I64_MIN
. In effetti, le abs
funzioni non possono essere usate per garantire un valore positivo.
Requisiti
Ciclo | Intestazione C obbligatoria | Intestazione C++ obbligatoria |
---|---|---|
abs , labs , llabs |
<math.h> oppure <stdlib.h> |
<cmath> , <cstdlib> , <stdlib.h> o <math.h> |
_abs64 |
<stdlib.h> |
<cstdlib> oppure <stdlib.h> |
Per usare le versioni di overload di abs
in C++, è necessario includere l'intestazione <cmath>
.
Esempio
Questo programma calcola e visualizza i valori assoluti di diversi numeri.
// crt_abs.c
// Build: cl /W3 /TC crt_abs.c
// This program demonstrates the use of the abs function
// by computing and displaying the absolute values of
// several numbers.
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <limits.h>
int main( void )
{
int ix = -4;
long lx = -41567L;
long long llx = -9876543210LL;
__int64 wx = -1;
// absolute 32 bit integer value
printf_s("The absolute value of %d is %d\n", ix, abs(ix));
// absolute long integer value
printf_s("The absolute value of %ld is %ld\n", lx, labs(lx));
// absolute long long integer value
printf_s("The absolute value of %lld is %lld\n", llx, llabs(llx));
// absolute 64 bit integer value
printf_s("The absolute value of 0x%.16I64x is 0x%.16I64x\n", wx,
_abs64(wx));
// Integer error cases:
printf_s("Microsoft implementation-specific results:\n");
printf_s(" abs(INT_MIN) returns %d\n", abs(INT_MIN));
printf_s(" labs(LONG_MIN) returns %ld\n", labs(LONG_MIN));
printf_s(" llabs(LLONG_MIN) returns %lld\n", llabs(LLONG_MIN));
printf_s(" _abs64(_I64_MIN) returns 0x%.16I64x\n", _abs64(_I64_MIN));
}
The absolute value of -4 is 4
The absolute value of -41567 is 41567
The absolute value of -9876543210 is 9876543210
The absolute value of 0xffffffffffffffff is 0x0000000000000001
Microsoft implementation-specific results:
abs(INT_MIN) returns -2147483648
labs(LONG_MIN) returns -2147483648
llabs(LLONG_MIN) returns -9223372036854775808
_abs64(_I64_MIN) returns 0x8000000000000000
Vedi anche
Conversione dati
Supporto matematico e a virgola mobile
_cabs
fabs
, fabsf
, fabsl
imaxabs