名稱空間
變體
操作

浮點字面量

來自 cppreference.com
< cpp‎ | 語言
 
 
C++ 語言
 
 

浮點字面量定義了一個編譯時常量,其值在原始檔中指定。

目錄

[編輯] 語法

數字序列 十進位制指數 字尾 (可選) (1)
數字序列 . 十進位制指數 (可選) 字尾 (可選) (2)
數字序列 (可選) . 數字序列 十進位制指數 (可選) 字尾 (可選) (3)
0x | 0X 十六進位制數字序列 十六進位制指數 字尾 (可選) (4) (C++17 起)
0x | 0X 十六進位制數字序列 . 十六進位制指數 字尾 (可選) (5) (C++17 起)
0x | 0X 十六進位制數字序列 (可選) . 十六進位制數字序列 十六進位制指數 字尾 (可選) (6) (C++17 起)
1) 數字序列表示一個沒有小數分隔符的整數,在這種情況下,指數不是可選的:1e10, 1e-5L
2) 數字序列表示一個帶小數分隔符的整數,在這種情況下,指數是可選的:1., 1.e-2
3) 數字序列表示一個小數。指數是可選的:3.14, .1f, 0.1e-1L
4) 十六進位制 數字序列表示一個沒有基數分隔符的整數。對於十六進位制浮點字面量,指數絕不是可選的:0x1ffp10, 0X0p-1
5) 十六進位制 數字序列表示一個帶基數分隔符的整數。對於十六進位制浮點字面量,指數絕不是可選的:0x1.p0, 0xf.p-1
6) 十六進位制 數字序列表示一個帶基數分隔符的分數。對於十六進位制浮點字面量,指數絕不是可選的:0x0.123p-1, 0xa.bp10l

十進位制指數 的形式是

e | E 指數符號 (可選) 數字序列

十六進位制指數 的形式是

p | P 指數符號 (可選) 數字序列 (C++17 起)

指數符號,如果存在,是 +-

字尾,如果存在,是 f, l, F, L 之一, f16, f32, f64, f128, bf16, F16, F32, F64, F128, BF16(C++23 起)。字尾決定了浮點字面量的型別。

  • (無後綴) 定義 double
  • f F 定義 float
  • l L 定義 long double
  • f16 F16 定義 std::float16_t
  • f32 F32 定義 std::float32_t
  • f64 F64 定義 std::float64_t
  • f128 F128 定義 std::float128_t
  • bf16 BF16 定義 std::bfloat16_t
(C++23 起)

可選的單引號(')可以插入數字之間作為分隔符;在確定字面量的值時它們會被忽略。

(C++14 起)

[編輯] 解釋

使用十進位制科學記數法,這意味著浮點字面量的值是有效數字乘以 10 的 十進位制指數 次冪。例如,123e4 的數學含義是 123×104

如果浮點字面量以字元序列 0x0X 開頭,則該浮點字面量是一個十六進位制浮點字面量。否則,它是一個十進位制浮點字面量

對於十六進位制浮點字面量,有效數字被解釋為十六進位制有理數,指數的數字序列被解釋為 2 的(十進位制)整數次冪,有效數字需要按此比例縮放。

double d = 0x1.4p3;// 十六進位制分數 1.4(十進位制 1.25)按 23 縮放,即 10.0

(C++17 起)

[編輯] 注意

十六進位制浮點字面量直到 C++17 才成為 C++ 的一部分,儘管自 C++11 以來它們可以透過 I/O 函式進行解析和列印:當 std::hexfloat 啟用時,C++ I/O 流和 C I/O 流都可以:std::printf, std::scanf 等。有關格式說明,請參見 std::strtof

功能測試宏 標準 特性
__cpp_hex_float 201603L (C++17) 十六進位制浮點字面量

[編輯] 示例

#include <iomanip>
#include <iostream>
#include <limits>
#include <typeinfo>
 
#define OUT(x) '\n' << std::setw(16) << #x << x
 
int main()
{
    std::cout
        << "Literal" "\t" "Printed value" << std::left
        << OUT( 58.            ) // double
        << OUT( 4e2            ) // double
        << OUT( 123.456e-67    ) // double
        << OUT( 123.456e-67f   ) // float, truncated to zero
        << OUT( .1E4f          ) // float
        << OUT( 0x10.1p0       ) // double
        << OUT( 0x1p5          ) // double
        << OUT( 0x1e5          ) // integer literal, not floating-point
        << OUT( 3.14'15'92     ) // double, single quotes ignored (C++14)
        << OUT( 1.18e-4932l    ) // long double
        << std::setprecision(39)
        << OUT( 3.4028234e38f  ) // float
        << OUT( 3.4028234e38   ) // double
        << OUT( 3.4028234e38l  ) // long double
        << '\n';
 
    static_assert(3.4028234e38f == std::numeric_limits<float>::max());
 
    static_assert(3.4028234e38f ==  // ends with 4
                  3.4028235e38f);   // ends with 5
 
    static_assert(3.4028234e38 !=   // ends with 4
                  3.4028235e38);    // ends with 5
 
    // Both floating-point constants below are 3.4028234e38
    static_assert(3.4028234e38f !=  // a float (then promoted to double)
                  3.4028234e38);    // a double
}

可能的輸出

Literal         Printed value
58.             58
4e2             400
123.456e-67     1.23456e-65
123.456e-67f    0
.1E4f           1000
0x10.1p0        16.0625
0x1p5           32
0x1e5           485
3.14'15'92      3.14159
1.18e-4932l     1.18e-4932
3.4028234e38f   340282346638528859811704183484516925440
3.4028234e38    340282339999999992395853996843190976512
3.4028234e38l   340282339999999999995912555211526242304

[編輯] 參考

  • C++23 標準 (ISO/IEC 14882:2024)
  • 5.13.4 浮點字面量 [lex.fcon]
  • C++20 標準 (ISO/IEC 14882:2020)
  • 5.13.4 浮點字面量 [lex.fcon]
  • C++17 標準 (ISO/IEC 14882:2017)
  • 5.13.4 浮點字面量 [lex.fcon]
  • C++14 標準 (ISO/IEC 14882:2014)
  • 2.14.4 浮點字面量 [lex.fcon]
  • C++11 標準 (ISO/IEC 14882:2011)
  • 2.14.4 浮點字面量 [lex.fcon]
  • C++98 標準 (ISO/IEC 14882:1998)
  • 2.13.3 浮點字面量 [lex.fcon]

[編輯] 參閱

使用者定義字面量(C++11) 帶使用者定義字尾的字面量[編輯]
C 文件 關於 浮點常量