?
This document uses PHP Chinese website manual Release
在頭文件<stdlib.h>中定義 | ||
---|---|---|
float ldexpf( float arg, int exp ); | (1) | (since C99) |
double ldexp( double arg, int exp ); | (2) | |
long double ldexpl( long double arg, int exp ); | (3) | (since C99) |
Defined in header <tgmath.h> | ||
#define ldexp( arg, exp ) | (4) | (since C99) |
1-3)arg
將數字2 的浮點值乘以exp
功率。
4)類型 - 通用宏:如果arg
有類型long double
,ldexpl
被調用。否則,如果arg
有整數類型或類型double
,ldexp
則調用。否則ldexpf
,分別稱為。
arg | - | 浮點值 |
---|---|---|
exp | - | 整數值 |
如果沒有錯誤發(fā)生,arg
乘以2的冪exp
(arg×2exp
)返回。
如果范圍誤差由于發(fā)生溢出,±HUGE_VAL
,±HUGE_VALF
,或±HUGE_VALL
返回。
如果發(fā)生下溢引起的范圍錯誤,則返回正確的結果(舍入后)。
按照math_errhandling中的指定報告錯誤。
如果實現支持IEEE浮點運算(IEC 60559),
除非發(fā)生范圍錯誤,否則FE_INEXACT
不會引發(fā)(結果是確切的)
除非發(fā)生范圍錯誤,否則當前舍入模式將被忽略
如果arg
為±0,則返回,未修改
如果arg
是±∞,則返回,未修改
如果exp
為0,則arg
返回,未修改
如果arg
是NaN,則返回NaN
二進制系統(tǒng)(其中,FLT_RADIX
是2
),ldexp
相當于scalbn
。
函數ldexp
(“加載指數”)及其雙數,frexp
可以用來操縱浮點數的表示,而無需直接位操作。
在許多實現中,ldexp
使用算術運算符的乘法或除法乘以二的冪的效率較低。
#include <stdio.h>#include <math.h>#include <float.h>#include <errno.h>#include <fenv.h>#pragma STDC FENV_ACCESS ON int main(void){ printf("ldexp(7, -4) = %f\n", ldexp(7, -4)); printf("ldexp(1, -1074) = %g (minimum positive subnormal double)\n", ldexp(1, -1074)); printf("ldexp(nextafter(1,0), 1024) = %g (largest finite double)\n", ldexp(nextafter(1,0), 1024)); // special values printf("ldexp(-0, 10) = %f\n", ldexp(-0.0, 10)); printf("ldexp(-Inf, -1) = %f\n", ldexp(-INFINITY, -1)); //error handling errno = 0; feclearexcept(FE_ALL_EXCEPT); printf("ldexp(1, 1024) = %f\n", ldexp(1, 1024)); if(errno == ERANGE) perror(" errno == ERANGE"); if(fetestexcept(FE_OVERFLOW)) puts(" FE_OVERFLOW raised");}
可能的輸出:
ldexp(7, -4) = 0.437500ldexp(1, -1074) = 4.94066e-324 (minimum positive subnormal double)ldexp(nextafter(1,0), 1024) = 1.79769e+308 (largest finite double)ldexp(-0, 10) = -0.000000ldexp(-Inf, -1) = -infldexp(1, 1024) = inf errno == ERANGE: Numerical result out of range FE_OVERFLOW raised
C11標準(ISO / IEC 9899:2011):
7.12.6.6 ldexp函數(p:244)
7.25類型通用數學<tgmath.h>(p:373-375)
F.10.3.6 ldexp函數(p:522)
C99標準(ISO / IEC 9899:1999):
7.12.6.6 ldexp函數(p:225)
7.22類型通用數學<tgmath.h>(p:335-337)
F.9.3.6 ldexp函數(p:459)
C89 / C90標準(ISO / IEC 9899:1990):
4.5.4.3 ldexp函數