当前位置: C语言 -- 标准库 -- <math.h> -- lrintl

lrintl函数


概要:
#include <math.h>
long int lrintl(long double x);

描述:

该函数根据当前舍入模式,将参数x舍入为long int类型的最接近整数值。

如果舍入得到的值超出返回类型所能表示的范围,结果是未指定的,并且可能发生域错误或者范围错误(range error)


参数:
long double x

参数为一个long double类型的浮点数。


返回值:

函数返回long int类型的舍入得到的整数值。


范例:
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
/*函数lrintl范例*/

#include <fenv.h>
#include <math.h>
#include <stdio.h>

#pragma STDC FENV_ACCESS ON

/*获取当前舍入模式。*/
void showRoundingDirection(void)
{
    switch(fegetround())
    {
    case FE_DOWNWARD:
        puts("Round downward");
        break;
    case FE_TOWARDZERO:
        puts("Round toward zero");
        break;
    case FE_UPWARD:
        puts("Round upward");
        break;
    default:
        puts("Round to nearest");
        break;
    }
}

int main(void)
{
    long double x = 2.3L, y = 2.7L;

    printf("Default rounding direction: ");
    showRoundingDirection();

    printf("lrintl(%.2Lf) = %ld\n", x, lrintl(x));
    printf("lrintl(%.2Lf) = %ld\n", y, lrintl(y));

    fesetround(FE_UPWARD);  //改变当前舍入模式。
    printf("Current rounding direction: ");
    showRoundingDirection();

    printf("lrintl(%.2Lf) = %ld\n", x, lrintl(x));
    printf("lrintl(%.2Lf) = %ld\n", y, lrintl(y));

    return 0;
}


输出:

Default rounding direction: Round to nearest

lrintl(2.30) = 2

lrintl(2.70) = 3

Current rounding direction: Round upward

lrintl(2.30) = 3

lrintl(2.70) = 3


相关内容:
lrint 根据当前舍入模式将double类型参数舍入为整数值的函数。
lrintf 根据当前舍入模式将float类型参数舍入为整数值的函数。