다음을 통해 공유


floor, , floorffloorl

값의 하한을 계산합니다.

구문

double floor(
   double x
);
float floor(
   float x
); // C++ only
long double floor(
   long double x
); // C++ only
float floorf(
   float x
);
long double floorl(
   long double x
);
#define floor(X) // Requires C11 or higher

매개 변수

x
부동 소수점 값입니다.

반환 값

floor 함수는 x보다 작거나 같은 가장 큰 정수를 나타내는 부동 소수점 값을 반환합니다. 오류 반환이 없습니다.

입력 SEH 예외 _matherr 예외
± QNaN, IND 없음 _DOMAIN

floor에는 SSE2(스트리밍 SIMD 확장 2)를 사용하는 구현이 포함됩니다. SSE2 구현 사용에 대한 자세한 내용 및 제한 사항은 다음을 참조하세요 _set_SSE2_enable.

설명

C++에서는 오버로드를 허용하므로 floatlong double 값을 사용 및 반환하는 floor의 오버로드를 호출할 수 있습니다. C 프로그램에서 이 함수를 호출하기 위해 <tgmath.h> 매크로를 사용하지 않는 한, floor은 항상 double을 취하고 반환합니다.

<tgmath.h>floor() 매크로를 사용하는 경우 인수 형식에 따라 선택되는 함수 버전이 결정됩니다. 자세한 내용은 형식-제네릭 수학을 참조하세요.

기본적으로 이 함수의 전역 상태는 애플리케이션으로 범위가 지정됩니다. 이 동작을 변경하려면 CRT 전역 상태를 참조하세요.

요구 사항

함수 필수 헤더
floor, , floorffloorl <math.h>
floor 매크로 <tgmath.h>

호환성에 대한 자세한 내용은 호환성을 참조하세요.

예시

// crt_floor.c
// This example displays the largest integers
// less than or equal to the floating-point values 2.8
// and -2.8. It then shows the smallest integers greater
// than or equal to 2.8 and -2.8.

#include <math.h>
#include <stdio.h>

int main( void )
{
   double y;

   y = floor( 2.8 );
   printf( "The floor of 2.8 is %f\n", y );
   y = floor( -2.8 );
   printf( "The floor of -2.8 is %f\n", y );

   y = ceil( 2.8 );
   printf( "The ceil of 2.8 is %f\n", y );
   y = ceil( -2.8 );
   printf( "The ceil of -2.8 is %f\n", y );
}
The floor of 2.8 is 2.000000
The floor of -2.8 is -3.000000
The ceil of 2.8 is 3.000000
The ceil of -2.8 is -2.000000

참고 항목

수학 및 부동 소수점 지원
ceil, , ceilfceill
round, , roundfroundl
fmod, fmodf