C library standar - <float.h>
pengantar singkat
C file standar libraryfloat.h header berisi satu set konstanta yang terkait dengan nilai floating-point tergantung pada platform.konstanta ini diusulkan oleh ANSI C, yang membuat program yang lebih portabel. Sebelum menjelaskan konstanta ini, yang terbaik adalah untuk memperjelas float terdiri dari empat unsur dalam komposisi sebagai berikut:
组件 | 组件描述 |
---|---|
S | 符号 ( +/- ) |
b | 指数表示的基数,2 表示二进制,10 表示十进制,16 表示十六进制,等等... |
e | 指数,一个介于最小值e min和最大值e max之间的整数。 |
p | 精度,基数 b 的有效位数 |
Berdasarkan empat komponen di atas, nilai angka floating-point sebagai berikut:
floating-point = (S) pxb e
atau
floating-point = (+/-) presisi eksponen x basis
perpustakaan makro
Nilai berikut implementasi khusus, dan didefinisikan oleh directive #define, nilai-nilai ini tidak lebih rendah dari nilai yang diberikan di bawah ini. Harap dicatat bahwa semua contoh FLT mengacu pada jenis float, DBL mengacu pada tipe ganda, LDBL mengacu mengetik panjang ganda.
宏 | 描述 |
---|---|
FLT_ROUNDS | 定义浮点加法的舍入模式,它可以是下列任何一个值:
|
FLT_RADIX 2 | 这个宏定义了指数表示的基数。基数 2 表示二进制,基数 10 表示十进制,基数 16 表示十六进制。 |
FLT_MANT_DIG DBL_MANT_DIG LDBL_MANT_DIG | 这些宏定义了 FLT_RADIX 基数中的位数。 |
FLT_DIG 6 DBL_DIG 10 LDBL_DIG 10 | 这些宏定义了舍入后不会改变表示的十进制数字的最大值(基数 10)。 |
FLT_MIN_EXP DBL_MIN_EXP LDBL_MIN_EXP | 这些宏定义了基数为 FLT_RADIX 时的指数的最小负整数值。 |
FLT_MIN_10_EXP -37 DBL_MIN_10_EXP -37 LDBL_MIN_10_EXP -37 | 这些宏定义了基数为 10 时的指数的最小负整数值。 |
FLT_MAX_EXP DBL_MAX_EXP LDBL_MAX_EXP | 这些宏定义了基数为 FLT_RADIX 时的指数的最大整数值。 |
FLT_MAX_10_EXP +37 DBL_MAX_10_EXP +37 LDBL_MAX_10_EXP +37 | 这些宏定义了基数为 10 时的指数的最大整数值。 |
FLT_MAX 1E+37 DBL_MAX 1E+37 LDBL_MAX 1E+37 | 这些宏定义最大的有限浮点值。 |
FLT_EPSILON 1E-5 DBL_EPSILON 1E-9 LDBL_EPSILON 1E-9 | 这些宏定义了可表示的最小有效数字。 |
FLT_MIN 1E-37 DBL_MIN 1E-37 LDBL_MIN 1E-37 | 这些宏定义了最小的浮点值。 |
contoh
Contoh berikut menunjukkan penggunaan float.h beberapa konstanta didefinisikan dalam file.
#include <stdio.h> #include <float.h> int main() { printf("The maximum value of float = %.10e\n", FLT_MAX); printf("The minimum value of float = %.10e\n", FLT_MIN); printf("The number of digits in the number = %.10e\n", FLT_MANT_DIG); }
Mari kita mengkompilasi dan menjalankan program di atas, yang akan menghasilkan hasil sebagai berikut:
The maximum value of float = 3.4028234664e+38 The minimum value of float = 1.1754943508e-38 The number of digits in the number = 7.2996655210e-312