Namespaces
Variants

isfinite

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
isfinite
(C99)
(C99)
(C99)
(C99)
(C23)
Error and gamma functions
(C99)
(C99)
(C99)
(C99)
Types
Macro constants
Special floating-point values
Arguments and return values
Error handling
Fast operation indicators
Определено в заголовочном файле <math.h>
#define isfinite(arg) /* implementation defined */
(начиная с C99)

Определяет, имеет ли данное число с плавающей запятой arg конечное значение, то есть является нормальным, субнормальным или нулевым, но не бесконечностью или NaN. Макрос возвращает целочисленное значение.

FLT_EVAL_METHOD игнорируется: даже если аргумент вычисляется с большим диапазоном и точностью, чем его тип, он сначала преобразуется в свой семантический тип, и классификация основывается на этом.

Содержание

Параметры

arg - значение с плавающей запятой

Возвращаемое значение

Ненулевое целочисленное значение, если arg имеет конечное значение, 0 в противном случае.

Пример

#include <float.h>
#include <math.h>
#include <stdio.h>
int main(void)
{
    printf("isfinite(NAN)         = %d\n", isfinite(NAN));
    printf("isfinite(INFINITY)    = %d\n", isfinite(INFINITY));
    printf("isfinite(0.0)         = %d\n", isfinite(0.0));
    printf("isfinite(DBL_MIN/2.0) = %d\n", isfinite(DBL_MIN / 2.0));
    printf("isfinite(1.0)         = %d\n", isfinite(1.0));
    printf("isfinite(exp(800))    = %d\n", isfinite(exp(800)));
}

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

isfinite(NAN)         = 0
isfinite(INFINITY)    = 0
isfinite(0.0)         = 1
isfinite(DBL_MIN/2.0) = 1
isfinite(1.0)         = 1
isfinite(exp(800))    = 0

Ссылки

  • Стандарт C23 (ISO/IEC 9899:2024):
  • 7.12.3.2 Макрос isfinite (стр.: TBD)
  • Стандарт C17 (ISO/IEC 9899:2018):
  • 7.12.3.2 Макрос isfinite (стр.: TBD)
  • Стандарт C11 (ISO/IEC 9899:2011):
  • 7.12.3.2 Макрос isfinite (стр. 236)
  • Стандарт C99 (ISO/IEC 9899:1999):
  • 7.12.3.2 Макрос isfinite (стр: 216-217)

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

классифицирует заданное значение с плавающей точкой
(макрос-функция)
(C99)
проверяет, является ли заданное число бесконечностью
(макрос-функция)
(C99)
проверяет, является ли заданное число NaN
(макрос-функция)
проверяет, является ли заданное число нормальным
(макрос-функция)