Namespaces
Variants

HUGE_VALF, HUGE_VAL, HUGE_VALL

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
Macro constants
Special floating-point values
HUGE_VAL HUGE_VALF HUGE_VALL HUGE_VALD N
(C99) (C99) (C23)
Arguments and return values
Error handling
Fast operation indicators
Определено в заголовке <math.h>
#define HUGE_VALF /*определено реализацией*/
(начиная с C99)
#define HUGE_VAL  /*определено реализацией*/
#define HUGE_VALL /*определено реализацией*/
(начиная с C99)

Макросы HUGE_VALF , HUGE_VAL и HUGE_VALL раскрываются в положительные константные выражения с плавающей точкой, которые сравниваются равными значениям, возвращаемым функциями и операторами с плавающей точкой в случае переполнения (см. math_errhandling ).

Константа Объяснение
HUGE_VALF Раскрывается в положительное float выражение, указывающее на переполнение
HUGE_VAL Раскрывается в положительное double выражение, указывающее на переполнение, не обязательно представимое как float
HUGE_VALL Раскрывается в положительное long double выражение, указывающее на переполнение, не обязательно представимое как float или double

В реализациях, поддерживающих бесконечности с плавающей точкой, эти макросы всегда раскрываются в положительные бесконечности для float , double и long double соответственно.

Пример

#include <math.h>
#include <stdio.h>
int main(void)
{
    const double result = 1.0 / 0.0;
    printf("1.0/0.0 == %f\n", result);
    if (result == HUGE_VAL)
        puts("1.0/0.0 == HUGE_VAL");
}

Возможный вывод:

1.0/0.0 == inf
1.0/0.0 == HUGE_VAL

Ссылки

  • Стандарт C23 (ISO/IEC 9899:2024):
  • 7.12/3 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр.: TBD)
  • F.10/2 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр.: TBD)
  • Стандарт C17 (ISO/IEC 9899:2018):
  • 7.12/3 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр.: TBD)
  • F.10/2 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр.: TBD)
  • Стандарт C11 (ISO/IEC 9899:2011):
  • 7.12/3 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр: 231)
  • F.10/2 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр: 517)
  • Стандарт C99 (ISO/IEC 9899:1999):
  • 7.12/3 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр: 212)
  • F.9/2 HUGE_VAL, HUGE_VALF, HUGE_VALL (стр: 454)
  • Стандарт C89/C90 (ISO/IEC 9899:1990):
  • 4.5 HUGE_VAL

Смотрите также

вычисляется в положительную бесконечность или значение, гарантированно вызывающее переполнение float
(макрос-константа)
C++ documentation для HUGE_VAL