feholdexcept
來自 cppreference.com
定義於標頭檔案 <fenv.h> |
||
int feholdexcept( fenv_t* envp ); |
(C99 起) | |
首先,將當前浮點環境儲存到 envp
指向的物件(類似於 fegetenv),然後清除所有浮點狀態標誌,接著安裝非停止模式:未來的浮點異常將不會中斷執行(不會陷入),直到浮點環境透過 feupdateenv 或 fesetenv 恢復。
此函式可用於必須向呼叫者隱藏其可能引發的浮點異常的子程式的開頭。如果只需要抑制某些異常,而其他異常必須報告,則通常在清除不需要的異常後,透過呼叫 feupdateenv 來結束非停止模式。
目錄 |
[編輯] 引數
envp | - | 指向 fenv_t 型別物件的指標,浮點環境將儲存在此處 |
[編輯] 返回值
成功時返回 0,否則返回非零值。
[編輯] 示例
執行此程式碼
#include <stdio.h> #include <fenv.h> #include <float.h> #pragma STDC FENV_ACCESS ON void show_fe_exceptions(void) { printf("current exceptions raised: "); if(fetestexcept(FE_DIVBYZERO)) printf(" FE_DIVBYZERO"); if(fetestexcept(FE_INEXACT)) printf(" FE_INEXACT"); if(fetestexcept(FE_INVALID)) printf(" FE_INVALID"); if(fetestexcept(FE_OVERFLOW)) printf(" FE_OVERFLOW"); if(fetestexcept(FE_UNDERFLOW)) printf(" FE_UNDERFLOW"); if(fetestexcept(FE_ALL_EXCEPT)==0) printf(" none"); printf("\n"); } double x2 (double x) /* times two */ { fenv_t curr_excepts; /* Save and clear current f-p environment. */ feholdexcept(&curr_excepts); /* Raise inexact and overflow exceptions. */ printf("In x2(): x = %f\n", x=x*2.0); show_fe_exceptions(); feclearexcept(FE_INEXACT); /* hide inexact exception from caller */ /* Merge caller's exceptions (FE_INVALID) */ /* with remaining x2's exceptions (FE_OVERFLOW). */ feupdateenv(&curr_excepts); return x; } int main(void) { feclearexcept(FE_ALL_EXCEPT); feraiseexcept(FE_INVALID); /* some computation with invalid argument */ show_fe_exceptions(); printf("x2(DBL_MAX) = %f\n", x2(DBL_MAX)); show_fe_exceptions(); return 0; }
輸出
current exceptions raised: FE_INVALID In x2(): x = inf current exceptions raised: FE_INEXACT FE_OVERFLOW x2(DBL_MAX) = inf current exceptions raised: FE_INVALID FE_OVERFLOW
[編輯] 參考
- C11 標準 (ISO/IEC 9899:2011)
- 7.6.4.2 feholdexcept 函式 (p: 213-214)
- C99 標準 (ISO/IEC 9899:1999)
- 7.6.4.2 feholdexcept 函式 (p: 194-195)
[編輯] 參閱
(C99) |
恢復浮點環境並引發先前引發的異常 (函式) |
(C99) |
儲存或恢復當前浮點環境 (函式) |
(C99) |
預設浮點環境 (宏常量) |