float01.c

来自「开放源码的编译器open watcom 1.6.0版的源代码」· C语言 代码 · 共 25 行

C
25
字号
#include "fail.h"
#include <float.h>
#include <math.h>

double d = DBL_MAX;
double e = -DBL_MAX;
double f = DBL_MAX*DBL_EPSILON;

int almost( double v1, double v2 )
{
    return !( fabs( v1 - v2 ) < f );
}

int main() {
    --d;
    ++d;
    d/=2;
    if( almost( d, (DBL_MAX/2) ) ) fail(__LINE__);
    --e;
    ++e;
    e/=2;
    if( almost( e, -(DBL_MAX/2) ) ) fail(__LINE__);
    _PASS;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?