非常教程

C参考手册

数值 | Numerics

islessequal

Defined in header <math.h>

#define islessequal(x, y) /* implementation defined */

(since C99)

Determines if the floating point number x is less than or equal to the floating-point number y, without setting floating-point exceptions.

Parameters

x

-

floating point value

y

-

floating point value

Return value

Nonzero integral value if x <= y, ​0​ otherwise.

Notes

The built-in operator<= for floating-point numbers may raise FE_INVALID if one or both of the arguments is NaN. This function is a "quiet" version of operator<=.

Example

#include <stdio.h>
#include <math.h>
 
int main(void)
{
    printf("islessequal(2.0,1.0)      = %d\n", islessequal(2.0,1.0));
    printf("islessequal(1.0,2.0)      = %d\n", islessequal(1.0,2.0));
    printf("islessequal(1.0,1.0)      = %d\n", islessequal(1.0,1.0));
    printf("islessequal(INFINITY,1.0) = %d\n", islessequal(INFINITY,1.0));
    printf("islessequal(1.0,NAN)      = %d\n", islessequal(1.0,NAN));
 
    return 0;
}

Possible output:

islessequal(2.0,1.0)      = 0
islessequal(1.0,2.0)      = 1
islessequal(1.0,1.0)      = 1
islessequal(INFINITY,1.0) = 0
islessequal(1.0,NAN)      = 0

References

  • C11 standard (ISO/IEC 9899:2011):
    • 7.12.14.4 The islessequal macro (p: 260)
    • F.10.11 Comparison macros (p: 531)
  • C99 standard (ISO/IEC 9899:1999):
    • 7.12.14.4 The islessequal macro (p: 241)

See also

isgreaterequal (C99)

checks if the first floating-point argument is greater or equal than the second (function)

| C++ documentation for islessequal |

 © cppreference.com

Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.

http://en.cppreference.com/w/c/numeric/math/islessequal

C

C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。