定宽浮点数类型 (C++23 起)

来自cppreference.com
< cpp‎ | types


 
 
 
类型支持
基本类型
定宽整数类型 (C++11)
定宽浮点类型 (C++23)
数值极限
C 数值极限接口
运行时类型信息
 

如果实现支持以下任何 ISO 60559 类型作为扩展浮点数类型,那么:

  • 对应的宏会被定义为 1 以指定支持它
  • 对应的浮点数字面量后缀会可用
  • 会提供对应的类型别名
类型名称
 在标头 <stdfloat> 定义
字面量后缀预定义宏C 语言类型类型属性
用于存储的位数表示精度的位数表示指数的位数最大指数
float16_tf16F16__STDCPP_FLOAT16_T___Float161611515
float32_tf32F32__STDCPP_FLOAT32_T___Float3232248127
float64_tf64F64__STDCPP_FLOAT64_T___Float646453111023
float128_tf128F128__STDCPP_FLOAT128_T___Float1281281131516383
bfloat16_tbf16BF16__STDCPP_BFLOAT16_T__(无)1688127

注解

类型 std::bfloat16_t 被称为 Brain 浮点数

与可以是标准整数类型别名的定宽整数类型不同,定宽浮点数类型必然是扩展浮点数类型(而非 float / double / long double)的别名,因此不是标准浮点数类型的简单替代品。

示例

#include <stdfloat>
 
#if __STDCPP_FLOAT64_T__ != 1
    #error "要求 64 位浮点数类型"
#endif
 
int main()
{
    std::float64_t f = 0.1f64;
}

引用

  • C++23 标准(ISO/IEC 14882:2024):
  • 6.8.3 Optional extended floating-point types [basic.extended.fp]

参阅