Namespaces
Variants

float_t, double_t

From cppreference.net
< c ‎ | numeric ‎ | math
Common mathematical functions
Functions
Basic operations
(C99)
(C99)
(C99)
(C99) (C99) (C99) (C23)
Maximum/minimum operations
Exponential functions
Power functions
Trigonometric and hyperbolic functions
Nearest integer floating-point
(C99) (C99) (C99)
(C23) (C23) (C23) (C23)
Floating-point manipulation
Narrowing operations
(C23)
(C23)
(C23)
(C23)
(C23)
(C23)
Quantum and quantum exponent
Decimal re-encoding functions
Total order and payload functions
Classification
Error and gamma functions
(C99)
(C99)
(C99)
(C99)
Types
float_t double_t
(C99) (C99)
Macro constants
Special floating-point values
Arguments and return values
Error handling
Fast operation indicators
Défini dans l'en-tête <math.h>
typedef /* implementation-defined */ float_t
(depuis C99)
typedef /* implementation-defined */ double_t
(depuis C99)

Les types float_t et double_t sont des types flottants au moins aussi larges que float et double , respectivement, et tels que double_t est au moins aussi large que float_t . La valeur de FLT_EVAL_METHOD détermine les types de float_t et double_t .

FLT_EVAL_METHOD Explication
0 float_t et double_t sont équivalents respectivement à float et double
1 à la fois float_t et double_t sont équivalents à double
2 à la fois float_t et double_t sont équivalents à long double
other à la fois float_t et double_t sont définis par l'implémentation

Exemple

#include <float.h>
#include <math.h>
#include <stdio.h>
#define SHOW(expr) printf("%s = %d\n", #expr, (int)(expr))
int main()
{
    SHOW(FLT_EVAL_METHOD);
    SHOW(sizeof(float));
    SHOW(sizeof(float_t));
    SHOW(sizeof(double));
    SHOW(sizeof(double_t));
}

Sortie possible :

FLT_EVAL_METHOD = 1
sizeof(float) = 4
sizeof(float_t) = 8
sizeof(double) = 8
sizeof(double_t) = 8

Références

  • Norme C23 (ISO/CEI 9899:2024) :
  • 7.12 Mathématiques <math.h> (p: TBD)
  • Norme C17 (ISO/CEI 9899:2018) :
  • 7.12 Mathématiques <math.h> (p: À DÉTERMINER)
  • Norme C11 (ISO/IEC 9899:2011) :
  • 7.12 Mathématiques <math.h> (p: 231)
  • Norme C99 (ISO/CEI 9899:1999) :
  • 7.12 Mathématiques <math.h> (p. 212)

Voir aussi

spécifie la précision dans laquelle toutes les opérations arithmétiques sont effectuées
(constante macro)