C++ Reference: Standard C++ Library reference: C Library: cmath: log

C++官网参考链接:https://cplusplus.com/reference/cmath/log/

函数 
<cmath> <ctgmath>
log
C90
double log (double x);
C99
double log  (double x); 
float logf (float x); 
long double logl (long double x);
C++98
double log (double x);      
float log (float x);
long double log (long double x);
C++11
double log (double x);      
float log (float x);
long double log (long double x);     
double log (T x);           // additional overloads for integral types

计算自然对数
返回x的自然对数。
自然对数是以e为底的对数:自然指数函数exp的反函数。普通对数(以10为底)参见log10
C99
头文件<tgmath.h>提供了该函数的泛型类型的宏版本。
C++98
该函数在<complex><valarray>中被重载(参见complex logvalarray log) 
C++11
在此头文件(<cmath>)中为整型(integral types)提供了额外的重载:这些重载在计算之前有效地将x转换为double类型。
此函数在<complex><valarray>中也被重载(参见complex logvalarray log)。

形参
计算其对数的值。
如果实参为负,则发生定义域错误。

返回值
x的自然对数。
如果x是负数,则会导致定义域错误。
如果x为0,它可能会导致极点错误(取决于库实现)。
C90(C++98)
如果发生定义域错误,将全局变量errno设置为EDOM
如果发生极点错误,则全局变量errno设置为ERANGE
C99(C++11)
如果发生定义域错误: 
math_errhandling具有MATH_ERRNO集合:全局变量errno设置为EDOM
math_errhandling具有MATH_ERREXCEPT集合:将引发FE_INVALID
如果发生极点错误: 
math_errhandling具有MATH_ERRNO集合:全局变量errno设置为ERANGE
math_errhandling具有MATH_ERREXCEPT集合:引发FE_DIVBYZERO。 

用例
/* log example */
#include <stdio.h>      /* printf */
#include <math.h>       /* log */

int main ()
{
  double param, result;
  param = 5.5;
  result = log (param);
  printf ("log(%f) = %f\n", param, result );
  return 0;
}
输出:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_40186813

你的能量无可限量。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值