名稱空間
變體
操作

nearbyint, nearbyintf, nearbyintl

來自 cppreference.com
< c‎ | 數值‎ | 數學
 
 
 
常用數學函式
函式
基本操作
(C99)
(C99)
(C99)
(C99)(C99)(C99)(C23)
最大值/最小值操作
(C99)
(C99)
指數函式
(C23)
(C99)
(C99)
(C23)
(C23)

(C99)
(C99)(C23)
(C23)
(C23)
冪函式
(C99)
(C23)
(C23)

(C99)
(C23)
(C23)
三角函式和雙曲函式
(C23)
(C23)
(C23)
(C23)
(C99)
(C99)
(C99)
最近整數浮點數
(C99)(C99)(C99)
(C99)

nearbyint
(C99)
(C99)(C99)(C99)
(C23)(C23)(C23)(C23)
浮點數操作
(C99)(C99)
(C99)(C23)
(C99)
窄化操作
(C23)
(C23)
(C23)
(C23)
(C23)
(C23)
量子與量子指數
十進位制重新編碼函式
總序和載荷函式
分類
(C99)
(C99)
(C99)
(C23)
誤差函式和伽馬函式
(C99)
(C99)
(C99)
(C99)
型別
宏常量
特殊浮點值
(C99)(C23)
引數和返回值
錯誤處理
快速操作指示符
 
定義於標頭檔案 <math.h>
float       nearbyintf( float arg );
(1) (C99 起)
double      nearbyint( double arg );
(2) (C99 起)
long double nearbyintl( long double arg );
(3) (C99 起)
定義於標頭檔案 <tgmath.h>
#define nearbyint( arg )
(4) (C99 起)
1-3) 使用 當前舍入模式 將浮點引數 arg 舍入為浮點格式的整數值。
4) 型別泛型宏:如果 arg 的型別為 long double,則呼叫 nearbyintl。否則,如果 arg 具有整數型別或型別 double,則呼叫 nearbyint。否則,呼叫 nearbyintf

目錄

[編輯] 引數

arg - 浮點值

[編輯] 返回值

返回 arg 最接近的整數值,根據 當前舍入模式

[編輯] 錯誤處理

此函式不受 math_errhandling 中指定的任何錯誤影響。

如果實現支援 IEEE 浮點運算 (IEC 60559),

  • FE_INEXACT 從不引發。
  • 如果 arg 是 ±∞,則返回它,不作修改。
  • 如果 arg 是 ±0,則返回它,不作修改。
  • 如果 arg 是 NaN,則返回 NaN。

[編輯] 注意

nearbyintrint 之間唯一的區別是 nearbyint 永不引發 FE_INEXACT

在所有標準浮點格式中,最大可表示浮點值都是精確整數,因此 nearbyint 本身不會溢位;但是,當儲存在整數變數中時,結果可能會溢位任何整數型別(包括 intmax_t)。

如果當前舍入模式是 FE_TONEAREST,則此函式在半途情況(例如 rint,但不同於 round)下向偶數舍入。

[編輯] 示例

#include <fenv.h>
#include <math.h>
#include <stdio.h>
 
int main(void)
{
// #pragma STDC FENV_ACCESS ON
    fesetround(FE_TONEAREST);
    printf("rounding to nearest:\nnearbyint(+2.3) = %+.1f  ", nearbyint(2.3));
    printf("nearbyint(+2.5) = %+.1f  ", nearbyint(2.5));
    printf("nearbyint(+3.5) = %+.1f\n", nearbyint(3.5));
    printf("nearbyint(-2.3) = %+.1f  ", nearbyint(-2.3));
    printf("nearbyint(-2.5) = %+.1f  ", nearbyint(-2.5));
    printf("nearbyint(-3.5) = %+.1f\n", nearbyint(-3.5));
 
    fesetround(FE_DOWNWARD);
    printf("rounding down: \nnearbyint(+2.3) = %+.1f  ", nearbyint(2.3));
    printf("nearbyint(+2.5) = %+.1f  ", nearbyint(2.5));
    printf("nearbyint(+3.5) = %+.1f\n", nearbyint(3.5));
    printf("nearbyint(-2.3) = %+.1f  ", nearbyint(-2.3));
    printf("nearbyint(-2.5) = %+.1f  ", nearbyint(-2.5));
    printf("nearbyint(-3.5) = %+.1f\n", nearbyint(-3.5));
 
    printf("nearbyint(-0.0) = %+.1f\n", nearbyint(-0.0));
    printf("nearbyint(-Inf) = %+.1f\n", nearbyint(-INFINITY));
}

輸出

rounding to nearest:
nearbyint(+2.3) = +2.0  nearbyint(+2.5) = +2.0  nearbyint(+3.5) = +4.0
nearbyint(-2.3) = -2.0  nearbyint(-2.5) = -2.0  nearbyint(-3.5) = -4.0
rounding down:
nearbyint(+2.3) = +2.0  nearbyint(+2.5) = +2.0  nearbyint(+3.5) = +3.0
nearbyint(-2.3) = -3.0  nearbyint(-2.5) = -3.0  nearbyint(-3.5) = -4.0
nearbyint(-0.0) = -0.0
nearbyint(-Inf) = -inf

[編輯] 參考

  • C23 標準 (ISO/IEC 9899:2024)
  • 7.12.9.3 nearbyint 函式 (p: TBD)
  • 7.25 型別通用數學 <tgmath.h> (p: TBD)
  • F.10.6.3 nearbyint 函式 (p: TBD)
  • C17 標準 (ISO/IEC 9899:2018)
  • 7.12.9.3 nearbyint 函式 (p: TBD)
  • 7.25 型別通用數學 <tgmath.h> (p: TBD)
  • F.10.6.3 nearbyint 函式 (p: TBD)
  • C11 標準 (ISO/IEC 9899:2011)
  • 7.12.9.3 nearbyint 函式 (p: 251-252)
  • 7.25 型別通用數學 <tgmath.h> (p: 373-375)
  • F.10.6.3 nearbyint 函式 (p: 526)
  • C99 標準 (ISO/IEC 9899:1999)
  • 7.12.9.3 nearbyint 函式 (p: 232)
  • 7.22 型別通用數學 <tgmath.h> (p: 335-337)
  • F.9.6.3 nearbyint 函式 (p: 463)

[編輯] 另請參閱

(C99)(C99)(C99)(C99)(C99)(C99)(C99)(C99)(C99)
使用當前舍入模式四捨五入到整數
如果結果不同則丟擲異常
(函式) [編輯]
(C99)(C99)(C99)(C99)(C99)(C99)(C99)(C99)(C99)
四捨五入到最接近的整數,在半數情況下遠離零
(函式) [編輯]
獲取或設定舍入方向
(函式) [編輯]
C++ 文件 for nearbyint