std::log10, std::log10f, std::log10l

来自cppreference.com
< cpp‎ | numeric‎ | math
 
 
 
 
在标头 <cmath> 定义
(1)
float       log10 (float num );

double      log10 (double num );

longdouble log10 (longdouble num );
(C++23 前)
/* 浮点数类型 */
            log10 (/* 浮点数类型 */ num );
(C++23 起)
(C++26 起 constexpr)
float       log10f(float num );
(2) (C++11 起)
(C++26 起为 constexpr)
longdouble log10l(longdouble num );
(3) (C++11 起)
(C++26 起为 constexpr)
SIMD 重载(C++26 起)
在标头 <simd> 定义
template</*math-floating-point*/ V >

constexpr/*deduced-simd-t*/<V>

            log10 (const V& v_num );
(S) (C++26 起)
额外重载(C++11 起)
在标头 <cmath> 定义
template<class Integer >
double      log10 ( Integer num );
(A) (C++26 起为 constexpr)
1-3) 计算 num常用(底数为 10)对数标准库提供所有以无 cv 限定的浮点数类型作为形参的类型的 std::log10 重载。(C++23 起)
S) SIMD 重载对 v_num 实施逐元素 std::log10
(参见 math-floating-pointdeduced-simd-t 的定义。)
(C++26 起)
A) 为所有整数类型提供额外重载,将它们当做 double
(C++11 起)

目录

[编辑]参数

num - 浮点数或整数

[编辑]返回值

如果没有发生错误,那么返回 num 的常用(底数为 10)对数(log10(num)lg(num))。

如果发生定义域错误,那么返回值由实现定义(在支持的平台上是 NaN)。

如果发生极点错误,那么返回 -HUGE_VAL-HUGE_VALF-HUGE_VALL

[编辑]错误处理

报告 math_errhandling 中指定的错误。

如果 num 小于零,那么发生定义域错误。

如果 num 为零,那么可能发生极点错误。

如果实现支持 IEEE 浮点数算术(IEC 60559),那么

  • 如果实参是 ±0,那么返回 -∞ 并引发 FE_DIVBYZERO
  • 如果实参是 1,那么返回 +0。
  • 如果实参是负数,那么返回 NaN 并引发 FE_INVALID
  • 如果实参是 +∞,那么返回 +∞。
  • 如果实参是 NaN,那么返回 NaN。

[编辑]注解

额外重载不需要以 (A) 的形式提供。它们只需要能够对它们的整数类型实参 num 确保 std::log10(num)std::log10(static_cast<double>(num)) 的效果相同。

[编辑]示例

#include <cerrno>#include <cfenv>#include <cmath>#include <cstring>#include <iostream>// #pragma STDC FENV_ACCESS ON   int main(){std::cout<<"log10(1000) = "<< std::log10(1000)<<'\n'<<"log10(0.001) = "<< std::log10(0.001)<<'\n'<<"125 以 5 为底的对数 = "<< std::log10(125)/ std::log10(5)<<'\n';   // 特殊值std::cout<<"log10(1) = "<< std::log10(1)<<'\n'<<"log10(+Inf) = "<< std::log10(INFINITY)<<'\n';   // 错误处理errno=0;std::feclearexcept(FE_ALL_EXCEPT);   std::cout<<"log10(0) = "<< std::log10(0)<<'\n';   if(errno==ERANGE)std::cout<<" errno == ERANGE: "<<std::strerror(errno)<<'\n';if(std::fetestexcept(FE_DIVBYZERO))std::cout<<" 发生 FE_DIVBYZERO\n";}

可能的输出:

log10(1000) = 3 log10(0.001) = -3 125 以 5 为底的对数 = 3 log10(1) = 0 log10(+Inf) = inf log10(0) = -inf errno == ERANGE: Numerical result out of range 发生 FE_DIVBYZERO

[编辑]参阅

(C++11)(C++11)
计算自然(以 e 为底)对数(ln(x)
(函数)[编辑]
(C++11)(C++11)(C++11)
给定数值的以 2 为底的对数(log2(x)
(函数)[编辑]
(C++11)(C++11)(C++11)
1 加上给定数值的自然(以 e 为底)对数(ln(1+x)
(函数)[编辑]
沿负实轴分割的复常用对数
(函数模板)[编辑]
应用函数 std::log10 到 valarray 的每个元素
(函数模板)[编辑]
log10 的 C 文档
close