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

来自cppreference.com
< cpp‎ | types


 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

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

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

  • 对应的宏会被定义为 1 以指定支持它
  • 对应的浮点字面量后缀会可用
  • 会提供对应的类型别名
类型名称
 在标头 <stdfloat> 定义 
字面量后缀 预定义宏  C 语言类型  类型属性
 用于存储 
的位数
 表示精度 
的位数
 表示指数 
的位数
 最大指数 
std::float16_t f16F16 __STDCPP_FLOAT16_T__ _Float16 16 11 5 15
std::float32_t f32F32 __STDCPP_FLOAT32_T__ _Float32 32 24 8 127
std::float64_t f64F64 __STDCPP_FLOAT64_T__ _Float64 64 53 11 1023
std::float128_t f128F128 __STDCPP_FLOAT128_T__ _Float128 128 113 15 16383
std::bfloat16_t bf16BF16 __STDCPP_BFLOAT16_T__ (无) 16 8 8 127

注解

类型 std::bfloat16_t 被称为 Brain 浮点(其中 Brain 来自 Google 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]

参阅