Namespaces
Variants

INFINITY

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
INFINITY DEC_INFINITY
(C99) (C23)
(C99) (C23)
Arguments and return values
Error handling
Fast operation indicators
Definido en el encabezado <math.h>
#define INFINITY /*implementation defined*/
(desde C99)

Si la implementación admite infinitos de punto flotante, la macro INFINITY se expande a una expresión constante de tipo float que evalúa a infinito positivo o infinito sin signo.

Si la implementación no admite infinitos de punto flotante, la macro INFINITY se expande a un valor positivo que garantiza desbordar un float en tiempo de compilación, y el uso de esta macro genera una advertencia del compilador.

El estilo utilizado para imprimir un infinito está definido por la implementación.

Ejemplo

Muestra el estilo utilizado para imprimir un infinito y formato IEEE.

#include <stdio.h>
#include <math.h>
#include <stdint.h>
#include <inttypes.h>
#include <string.h>
int main(void)
{
    double f = INFINITY;
    uint64_t fn; memcpy(&fn, &f, sizeof f);
    printf("INFINITY:   %f %" PRIx64 "\n", f, fn);
}

Salida posible:

INFINITY:   inf 7ff0000000000000

Referencias

  • Estándar C11 (ISO/IEC 9899:2011):
  • 7.12/4 INFINITY (p: 231-232)
  • Estándar C99 (ISO/IEC 9899:1999):
  • 7.12/4 INFINITY (p: 212-213)

Véase también

(C99)
comprueba si el número dado es infinito
(macro de función)
indica un valor demasiado grande para ser representable (infinito) por float , double y long double respectivamente
(constante macro)