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

lrintf函数


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

描述:

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

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


参数:
float x

参数为一个float类型的浮点数。


返回值:

函数返回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 
/*函数lrintf范例*/

#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)
{
    float x = 2.3f, y = 2.7f;

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

    printf("lrintf(%.2f) = %ld\n", x, lrintf(x));
    printf("lrintf(%.2f) = %ld\n", y, lrintf(y));

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

    printf("lrintf(%.2f) = %ld\n", x, lrintf(x));
    printf("lrintf(%.2f) = %ld\n", y, lrintf(y));

    return 0;
}


输出:

Default rounding direction: Round to nearest

lrintf(2.30) = 2

lrintf(2.70) = 3

Current rounding direction: Round upward

lrintf(2.30) = 3

lrintf(2.70) = 3


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