acos
, , acosf
acosl
Oblicza arcus cosinus.
Składnia
double acos( double x );
float acosf( float x );
long double acosl( long double x );
#define acos(X) // Requires C11 or higher
float acos( float x ); // C++ only
long double acos( long double x ); // C++ only
Parametry
x
Wartość z zakresu od -1 do 1, dla której ma być obliczana arcus cosinus (odwrotna cosinus).
Wartość zwracana
Funkcja acos
zwraca arcus cosinus z x
zakresu od 0 do π radianów.
Domyślnie, jeśli x
wartość jest mniejsza niż -1 lub większa niż 1, acos
zwraca czas nieokreślony.
Dane wejściowe | Wyjątek SEH | Wyjątek _matherr |
---|---|---|
± INF | INVALID |
_DOMAIN |
± QNaN, IND | Brak | _DOMAIN |
|x| > 1 |
INVALID |
_DOMAIN |
Uwagi
Ponieważ język C++ umożliwia przeciążenie, można wywołać przeciążenia tych operacji acos
, które przyjmują i zwracają float
i long double
typy. W programie języka C, chyba że używasz makra <tgmath.h>
do wywoływania tej funkcji, acos
zawsze przyjmuje i zwraca wartość double
.
Jeśli używasz makra acos
z <tgmath.h>
, typ argumentu określa, która wersja funkcji jest zaznaczona. Aby uzyskać szczegółowe informacje, zobacz Typy ogólne matematyczne .
Domyślnie stan globalny tej funkcji jest zakresem aplikacji. Aby zmienić to zachowanie, zobacz Stan globalny w CRT.
Wymagania
Procedura | Wymagany nagłówek | Opcjonalne nagłówki |
---|---|---|
acos , , acosf acosl |
<math.h> |
<errno.h> |
acos Makro |
<tgmath.h> |
Przykład
Ten program monituje o wartość z zakresu od -1 do 1. Wartości wejściowe poza tym zakresem generują _DOMAIN
komunikaty o błędach. Jeśli zostanie wprowadzona prawidłowa wartość, program wyświetli arcusinus i arcus cosinus tej wartości.
// crt_asincos.c
// arguments: 0
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main( int ac, char* av[] )
{
double x,
y;
errno_t err;
// argument checking
if (ac != 2)
{
fprintf_s( stderr, "Usage: %s <number between -1 and 1>\n",
av[0]);
return 1;
}
// Convert argument into a double value
if ((err = sscanf_s( av[1], "%lf", &x )) != 1)
{
fprintf_s( stderr, "Error converting argument into ",
"double value.\n");
return 1;
}
// Arcsine of X
y = asin( x );
printf_s( "Arcsine of %f = %f\n", x, y );
// Arccosine of X
y = acos( x );
printf_s( "Arccosine of %f = %f\n", x, y );
}
Arcsine of 0.000000 = 0.000000
Arccosine of 0.000000 = 1.570796
Zobacz też
Obsługa obliczeń matematycznych i zmiennoprzecinkowych
asin
, , asinf
asinl
atan
, , atanf
, atanl
, atan2
, , atan2f
atan2l
cos
, , cosf
cosl
_matherr
sin
, , sinf
sinl
tan
, , tanf
tanl