?
本文檔使用 PHP中文網手冊 發(fā)布
在頭文件<math.h>中定義 | ||
---|---|---|
float tanf(float arg); | (1) | (自C99以來) |
雙坦(double arg); | (2) | |
長雙重坦克(long double arg); | (3) | (自C99以來) |
在頭文件<tgmath.h>中定義 | ||
#define tan(arg) | (4) | (自C99以來) |
1-3)計算切線arg
(以弧度測量)。
4)類型 - 通用宏:如果參數具有類型long double
,tanl
則被調用。否則,如果參數具有整數類型或類型double
,tan
則調用該參數。否則,tanf
被調用。如果參數是復雜的,則宏調用相應的復變函數(ctanf
,ctan
,ctanl
)。
arg | - | 以弧度表示角度的浮點值 |
---|
如果沒有錯誤發(fā)生,arg
則返回(tan(arg))的正切值。
如果arg的大小很大,結果可能幾乎沒有意義。 | (直到C99) |
---|
如果發(fā)生域錯誤,則返回實現定義的值(NaN,如果支持)。
如果由于下溢而發(fā)生范圍錯誤,則返回正確的結果(舍入后)。
按照math_errhandling中的指定報告錯誤。
如果實現支持IEEE浮點運算(IEC 60559),
如果參數為±0,則不加修改地返回
如果參數是±∞,則返回并FE_INVALID
提升NaN
如果參數是NaN,則返回NaN
參數無限的情況在C中沒有被指定為域錯誤,但是在POSIX中被定義為域錯誤。
該函數在π(1/2 + n)處具有數學極點;然而,沒有共同的浮點表示法能夠精確地表示π/2,因此沒有出現極點錯誤的參數值。
#include <stdio.h>#include <math.h>#include <errno.h>#include <fenv.h> #pragma STDC FENV_ACCESS ON int main(void){ double pi = acos(-1); // typical usage printf("tan (pi/4) = %+f\n", tan( pi/4)); // 45 deg printf("tan(3*pi/4) = %+f\n", tan(3*pi/4)); // 135 deg printf("tan(5*pi/4) = %+f\n", tan(5*pi/4)); // -135 deg printf("tan(7*pi/4) = %+f\n", tan(7*pi/4)); // -45 deg // special values printf("tan(+0) = %f\n", tan(0.0)); printf("tan(-0) = %f\n", tan(-0.0)); // error handling feclearexcept(FE_ALL_EXCEPT); printf("tan(INFINITY) = %f\n", tan(INFINITY)); if(fetestexcept(FE_INVALID)) puts(" FE_INVALID raised");}
可能的輸出:
tan (pi/4) = +1.000000tan(3*pi/4) = -1.000000tan(5*pi/4) = +1.000000tan(7*pi/4) = -1.000000tan(+0) = 0.000000tan(-0) = -0.000000tan(INFINITY) = -nan FE_INVALID raised
C11標準(ISO/IEC 9899:2011):
7.12.4.7 tan函數(p:240)
7.25類型通用數學<tgmath.h>(p:373-375)
F.10.1.7 tan函數(p:519)
C99標準(ISO/IEC 9899:1999):
7.12.4.7 tan函數(p:220)
7.22類型通用數學<tgmath.h>(p:335-337)
F.9.1.7 tan函數(p:457)
C89/C90標準(ISO/IEC 9899:1990):
4.5.2.7 tan函數
sinsinfsinl(C99)(C99) | 計算正弦(sin(x))(函數) |
---|---|
coscosfcosl(C99)(C99) | 計算余弦(cos(x))(函數) |
atanatanfatanl(C99)(C99) | 計算反正切(arctan(x))(函數) |
(C99)(C99)(C99) | 計算復正切(函數) |
| 用于tan |的C ++文檔