在我的程序中,某些计算可能会生成1.#INF00
或-1.#IND00
个结果
我想打印这些结果 - 但不是1.#INF00
和-1.#IND00
。例如,对于1.#INF00,我想要打印“无限”
infinity_print(computation(x));//results infinity result 1.#INF00
会导致“无限”出现在屏幕上
如何实施infinity_print?
答案 0 :(得分:1)
您可以在c99中使用isinf(y)宏。否则它取决于你的编译器,操作系统,架构 - 不同的实现有各种缺点。
以下是一些可能的变体:
#include <math.h> /* isinf */
#ifndef isinf
/* Microsoft C defines _MSC_VER */
#ifdef _MSC_VER
# include <float.h>
/*
from Python source: PC/pyconfig.h Py_IS_INFINITY
*/
# define isinf(X) (!_finite(X) && !_isnan(X))
#else
# ifndef isnan
/*
http://www.gnu.org/software/hello/manual/autoconf/Function-Portability.html
*/
# define isnan(X) isnan_d(X)
static inline int isnan_d (double x) { return x != x; }
# endif /* !isnan */
# define isinf(X) isinf_d(X)
static inline int isinf_d (double x) { return !isnan (x) && isnan (x - x); }
#endif /* _MSC_VER */
#endif /* !isinf */
#ifdef gnulib
/*
http://git.savannah.gnu.org/gitweb/?p=gnulib.git;a=blob;f=lib/isinf.c;hb=HEAD
*/
#undef isinf
#define isinf(X) gl_isinfd(X)
#include <float.h>
static inline int gl_isinfd (double x) { return x < -DBL_MAX || x > DBL_MAX; }
#endif /* gnulib */
对于float
,long double
实现类似。
#include <stdio.h>
int main() {
double x = 1./0;
printf("%g", x);
if (isinf(x))
puts(" infinity");
puts("\n");
return 0;
}