#include <stdio.h>
#include <float.h>
#ifdef FLT_EVAL_METHOD
#undef FLT_EVAL_METHOD
#define FLT_EVAL_METHOD 1
#else
#define FLT_EVAL_METHOD 1
#endif
int main(void)
{
printf("%f\n%f\n", FLT_MAX, DBL_MAX);
float fp = FLT_MAX;
printf("%f\n", fp + 1);
printf("%f\n", FLT_MAX + 1);
printf("%f\n", (float) FLT_MAX + 1);
}
预期输出为:
340282346638528859811704183484516925440.000000
179769313486231570814527423731704356798070567525844996598917476803157260780028538760589558632766878171540458953514382464234321326889464182768467546703537516986049910576551282076245490090389328944075868508455133942304583236903222948165808559332123348274797826204144723168738177180919299881250404026184124858368.000000
340282346638528859811704183484516925441.000000
340282346638528859811704183484516925441.000000
340282346638528859811704183484516925441.000000
但实际输出是:
340282346638528859811704183484516925440.000000
179769313486231570814527423731704356798070567525844996598917476803157260780028538760589558632766878171540458953514382464234321326889464182768467546703537516986049910576551282076245490090389328944075868508455133942304583236903222948165808559332123348274797826204144723168738177180919299881250404026184124858368.000000
340282346638528859811704183484516925440.000000
340282346638528859811704183484516925440.000000
340282346638528859811704183484516925440.000000
由于FLT_EVAL_METHOD
设置为1,所有float
个表达式不应该评估为double
吗?什么“评价浮动和加倍为双倍,长加倍为双倍。”意思? float
被视为与double
s相同吗?
答案 0 :(得分:6)
FLT_EVAL_METHOD
不是程序员用来控制编译器的开关。它是编译器/平台向程序员报告如何评估浮点表达式的一种手段。你不应该改变它的价值,这样做不应该对任何事情产生任何影响。