命名空间
变体
操作

浮点环境 (自 C++11 起)

来自 cppreference.cn
< cpp‎ | numeric
 
 
 
浮点环境
函数
(C++11)(C++11)
(C++11)(C++11)
宏常量
(C++11)
 

浮点环境是由实现所支持的浮点状态标志和控制模式的集合。它是线程局部的。每个线程从父线程继承其浮点环境的初始状态。浮点运算会修改浮点状态标志以指示异常结果或辅助信息。浮点控制模式的状态会影响某些浮点运算的结果。

只有当支持 #pragma STDC FENV_ACCESS 并设置为 ON 时,浮点环境的访问和修改才有意义。否则,实现可以自由地假设浮点控制模式始终是默认模式,并且浮点状态标志永远不会被测试或修改。实际上,很少有当前的编译器(如 HP aCC、Oracle Studio 或 IBM XL)显式支持 #pragma,但大多数编译器仍然允许对浮点环境进行有意义的访问。

目录

[edit] 类型

定义于头文件 <cfenv>
fenv_t
(C++11)
表示整个浮点环境的类型
(typedef) [edit]
fexcept_t
(C++11)
表示所有浮点状态标志集合的类型
(typedef) [edit]

[edit] 函数

清除指定的浮点状态标志
(function) [edit]
确定已设置哪些指定的浮点状态标志
(function) [edit]
引发指定的浮点异常
(function) [edit]
从浮点环境复制或向其复制指定的浮点状态标志的状态
(function) [edit]
(C++11)(C++11)
获取或设置舍入方向
(function) [edit]
保存或恢复当前的浮点环境
(function) [edit]
保存环境,清除所有状态标志并忽略所有未来错误
(function) [edit]
恢复浮点环境并引发先前引发的异常
(function) [edit]

[edit]

浮点异常
(macro constant) [edit]
浮点舍入方向
(macro constant) [edit]
默认浮点环境
(macro constant) [edit]

[edit] 注释

浮点异常与 C++ 异常无关。当浮点运算引发浮点异常时,浮点环境的状态会发生变化,这可以使用 std::fetestexcept 进行测试,但在大多数实现上,C++ 程序的执行会继续不中断。

存在编译器扩展,可以在引发浮点异常时自动生成 C++ 异常

  • GNU libc 函数 feenableexcept() 允许捕获浮点异常,这会生成信号 SIGFPE。如果使用了编译器选项 -fnon-call-exceptions,则该信号的处理程序可能会抛出用户定义的 C++ 异常。
  • MSVC 函数 _control87() 允许捕获浮点异常,这会生成硬件异常,可以使用 _set_se_translator 将其转换为 C++ 异常。

[edit] 参见

C 文档 关于 浮点环境