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

nearbyintf函数


概要:
#include <math.h>
float nearbyintf(float x);

描述:

该函数根据当前舍入模式,将参数x舍入为浮点格式的整数值,并且不会生成FE_INEXACT浮点异常。


参数:
float x

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


返回值:

函数返回浮点格式表示的舍入得到的整数值。


范例:
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 
/*函数nearbyintf范例*/

#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("nearbyintf(%.2f) = %.2f\n", x, nearbyintf(x));
    printf("nearbyintf(%.2f) = %.2f\n", y, nearbyintf(y));

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

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

    return 0;
}


输出:

Default rounding direction: Round to nearest

nearbyintf(2.30) = 2.00

nearbyintf(2.70) = 3.00

Current rounding direction: Round upward

nearbyintf(2.30) = 3.00

nearbyintf(2.70) = 3.00


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