?
This document uses PHP Chinese website manual Release
在頭文件<math.h>中定義 | ||
---|---|---|
float log10f( float arg ); | (1) | (since C99) |
double log10( double arg ); | (2) | |
long double log10l( long double arg ); | (3) | (since C99) |
Defined in header <tgmath.h> | ||
#define log10( arg ) | (4) | (since C99) |
1-3)計算公共(基數為10)的對數arg
。
4)類型 - 通用宏:如果arg
有類型long double
,log10l
被調用。否則,如果arg
有整數類型或類型double
,log10
則調用。否則,log10f
被調用。
arg | - | 浮點值 |
---|
如果沒有錯誤發(fā)生,則以(log 10)的常見(以10為底)對數arg
10(arg)或lg(arg))。
如果發(fā)生域錯誤,則返回實現定義的值(NaN,如果支持)。
如果發(fā)生極錯誤-HUGE_VAL
,-HUGE_VALF
或-HUGE_VALL
返回。
按照math_errhandling中的指定報告錯誤。
如果arg
小于零,則會發(fā)生域錯誤。
如果arg
為零,則可能出現極點錯誤。
如果實現支持IEEE浮點運算(IEC 60559),
如果參數為±0,則返回-∞并FE_DIVBYZERO
引發(fā)。
如果參數是1,則返回+0
如果參數是否定的,則返回并FE_INVALID
提出NaN 。
如果參數是+∞,則返回+∞
如果參數是NaN,則返回NaN
#include <stdio.h>#include <math.h>#include <float.h>#include <errno.h>#include <fenv.h>#pragma STDC FENV_ACCESS ON int main(void){ printf("log10(1000) = %f\n", log10(1000)); printf("log10(0.001) = %f\n", log10(0.001)); printf("base-5 logarithm of 125 = %f\n", log10(125)/log10(5)); // special values printf("log10(1) = %f\n", log10(1)); printf("log10(+Inf) = %f\n", log10(INFINITY)); //error handling errno = 0; feclearexcept(FE_ALL_EXCEPT); printf("log10(0) = %f\n", log10(0)); if(errno == ERANGE) perror(" errno == ERANGE"); if(fetestexcept(FE_DIVBYZERO)) puts(" FE_DIVBYZERO raised");}
可能的輸出:
log10(1000) = 3.000000log10(0.001) = -3.000000base-5 logarithm of 125 = 3.000000log10(1) = 0.000000log10(+Inf) = inflog10(0) = -inf errno == ERANGE: Numerical result out of range FE_DIVBYZERO raised
C11標準(ISO / IEC 9899:2011):
7.12.6.8 log10函數(p:245)
7.25類型通用數學<tgmath.h>(p:373-375)
F.10.3.8 log10函數(p:522)
C99標準(ISO / IEC 9899:1999):
7.12.6.8 log10函數(p:225-226)
7.22類型通用數學<tgmath.h>(p:335-337)
F.9.3.8 log10函數(p:459)
C89 / C90標準(ISO / IEC 9899:1990):
4.5.4.5 log10函數