Udostępnij za pośrednictwem


acos, , acosfacosl

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, , acosfacosl <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, , asinfasinl
atan, , atanf, atanl, atan2, , atan2fatan2l
cos, , cosfcosl
_matherr
sin, , sinfsinl
tan, , tanftanl