FE_DFL_ENV

来自cppreference.com
< cpp‎ | numeric‎ | fenv


 
 
 
浮点环境
函数
(C++11)(C++11)
(C++11)(C++11)
宏常量
FE_DFL_ENV
(C++11)
 
在标头 <cfenv> 定义
#define FE_DFL_ENV  /* 由实现定义 */
(C++11 起)

宏常量 FE_DFL_ENV 展开成 const std::fenv_t* 类型的表达式,它指向默认浮点环境(即在程序加载时的浮点环境)的完整副本。

实现亦可支持附加的以 FE_ 开头并后随大写字母,并拥有 const std::fenv_t* 类型的宏。

示例

#include <cfenv>
#include <iostream>
// #pragma STDC FENV_ACCESS ON
 
void show_env()
{
    const int e = std::fetestexcept(FE_ALL_EXCEPT);
    if (e & FE_DIVBYZERO)
        std::cout << "已引发 除以零 (division by zero)\n";
    if (e & FE_INEXACT)
        std::cout << "已引发 不精确值 (inexact)\n";
    if (e & FE_INVALID)
        std::cout << "已引发 无效值 (invalid)\n";
    if (e & FE_UNDERFLOW)
        std::cout << "已引发 下溢出 (underflow)\n";
    if (e & FE_OVERFLOW)
        std::cout << "已引发 上溢出 (overflow)\n";
 
    switch (std::fegetround())
    {  
        case FE_DOWNWARD:
            std::cout << "向下舍入\n";
            break;
        case FE_TONEAREST:
            std::cout << "向最近舍入\n";
            break;
        case FE_TOWARDZERO:
            std::cout << "向零舍入\n";
            break;
        case FE_UPWARD:
            std::cout << "向上舍入\n";
            break;
    }
}
 
int main()
{
    std::cout << "启动时:\n";
    show_env();
 
    std::feraiseexcept(FE_UNDERFLOW | FE_OVERFLOW);
    std::fesetround(FE_UPWARD);
 
    std::cout << "\n恢复前:\n";
    show_env();
 
    std::fesetenv(FE_DFL_ENV);
 
    std::cout << "\n重置为默认值后:\n";
    show_env();
}

输出:

启动时: 
向最近舍入
 
恢复前: 
已引发 下溢出 (underflow)
已引发 上溢出 (overflow)
向上舍入
 
重置为默认值后: 
向最近舍入

参阅

保存或恢复当前浮点环境
(函数)
恢复浮点环境并引发之前引发的异常
(函数)