标准库标头 <cfenv> (C++11)

来自cppreference.com
< cpp‎ | header


 
 
标准库头
通用工具
<any> (C++17)
<bitset>
<bit> (C++20)
<charconv> (C++17)
<expected> (C++23)
<format> (C++20)
<functional>
<optional> (C++17)
<stdbit.h> (C++26)
<tuple> (C++11)
<typeindex> (C++11)
<utility>
<variant> (C++17)
容器
<array> (C++11)
<deque>
<flat_map> (C++23)
<flat_set> (C++23)
<forward_list> (C++11)
<hive> (C++26)
<inplace_vector> (C++26)   
<list>
<map>
<mdspan> (C++23)
<queue>
<set>
<span> (C++20)
<stack>
<unordered_map> (C++11)
<unordered_set> (C++11)
<vector>
迭代器
<iterator>
范围
<generator> (C++23)
<ranges> (C++20)
算法
<algorithm>
<numeric>
字符串
<cctype>
<cstring>
<cuchar> (C++11)
<cwchar>
<cwctype>
<string_view> (C++17)
<string>
文本处理
<clocale>
<codecvt> (C++11/17/26*)
<locale>
<regex> (C++11)
<text_encoding> (C++26)   
cpp/header#数值库数值
<cfenv> (C++11)
<cmath>
<complex>
<linalg> (C++26)
<numbers> (C++20)
<random> (C++11)
<simd> (C++26)
<stdckdint.h> (C++26)
<valarray>
时间
<chrono> (C++11)
<ctime>
C 兼容性
<ccomplex> (C++11/17/20*)
<ciso646> (C++20 前)
<cstdalign> (C++11/17/20*)
<cstdbool> (C++11/17/20*)
<ctgmath> (C++11/17/20*)
 

此标头原作为 <fenv.h> 存在于 C 标准库。

此头文件是浮点数环境库的一部分。

目录

[编辑] 类型

fenv_t
(C++11)
表示浮点数环境整体的类型
(typedef) [编辑]
fexcept_t
(C++11)
汇集地表示所有浮点数状态标志的类型
(typedef) [编辑]

[编辑] 函数

清除指定的浮点数状态标志
(函数) [编辑]
确定设置了哪个指定的浮点数状态标志
(函数) [编辑]
引发指定的浮点数异常
(函数) [编辑]
从浮点数环境(或向其中)复制指定的浮点数状态标志
(函数) [编辑]
(C++11)(C++11)
获取或设置舍入方向
(函数) [编辑]
保存或恢复当前浮点数环境
(函数) [编辑]
保存环境,清除所有状态标志,并忽略所有将来的错误
(函数) [编辑]
恢复浮点数环境并引发之前引发的异常
(函数) [编辑]

[编辑]

浮点数异常
(宏常量) [编辑]
浮点数舍入方向
(宏常量) [编辑]
默认浮点数环境
(宏常量) [编辑]

[编辑] 概要

#define FE_ALL_EXCEPT /* 见描述 */
#define FE_DIVBYZERO /* 见描述 */    // 可选
#define FE_INEXACT /* 见描述 */      // 可选
#define FE_INVALID /* 见描述 */      // 可选
#define FE_OVERFLOW /* 见描述 */     // 可选
#define FE_UNDERFLOW /* 见描述 */    // 可选
 
#define FE_DOWNWARD /* 见描述 */     // 可选
#define FE_TONEAREST /* 见描述 */    // 可选
#define FE_TOWARDZERO /* 见描述 */   // 可选
#define FE_UPWARD /* 见描述 */       // 可选
 
#define FE_DFL_ENV /* 见描述 */
 
namespace std {
    // 类型
    using fenv_t    = /* 对象类型 */;
    using fexcept_t = /* 对象类型 */;
 
    // 函数
    int feclearexcept(int except);
    int fegetexceptflag(fexcept_t* pflag, int except);
    int feraiseexcept(int except);
    int fesetexceptflag(const fexcept_t* pflag, int except);
    int fetestexcept(int except);
    int fegetround(void);
    int fesetround(int mode);
    int fegetenv(fenv_t* penv);
    int feholdexcept(fenv_t* penv);
    int fesetenv(const fenv_t* penv);
    int feupdateenv(const fenv_t* penv);
}

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 3905 C++11 std::fexcept_t 必须是整数类型 可以是对象类型