pow
, , powf
powl
x
의 y
승 값을 계산합니다.
구문
double pow( double x, double y );
float powf( float x, float y );
long double powl( long double x, long double y );
define pow(X, Y) // Requires C11 or higher
double pow( double x, int y ); // C++ only
float pow( float x, float y ); // C++ only
float pow( float x, int y ); // C++ only
long double pow( long double x, long double y ); // C++ only
long double pow( long double x, int y ); // C++ only
매개 변수
x
밑입니다.
y
지수입니다.
반환 값
x
y
의 값을 반환합니다. 오버플로 또는 언더플로 시 오류 메시지는 인쇄되지 않습니다.
및 값 x y |
의 반환 값 pow |
---|---|
x != 0.0 및 y == 0.0 |
1 |
x == 0.0 및 y == 0.0 |
1 |
x == 0.0 및 y < 0 |
INF |
설명
pow
는 264 보다 큰 정수 부동 소수점 값을 인식하지 못합니다(예: 1.0E100).
pow
에는 SSE2(스트리밍 SIMD 확장 2)를 사용하는 구현이 포함됩니다. SSE2 구현 사용에 대한 자세한 내용 및 제한 사항은 다음을 참조하세요 _set_SSE2_enable
.
C++에서는 오버로드를 허용하므로 pow
의 여러 오버로드 중 원하는 항목을 호출할 수 있습니다. C 프로그램에서는 매크로를 사용하여 <tgmath.h>
이 함수 pow
를 호출하지 않는 한 항상 두 double
값을 사용하고 값을 반환 double
합니다.
매크로<tgmath.h>
를 pow
사용하는 경우 인수 형식에 따라 선택한 함수 버전이 결정됩니다. 자세한 내용은 형식-제네릭 수학을 참조하세요.
pow(int, int)
오버로드는 더 이상 사용할 수 없습니다. 이 오버로드를 사용하는 경우 컴파일러는 C2668을 내보낸다. 이 문제를 방지하려면 첫 번째 매개 변수를 double
, float
또는 long double
로 캐스팅합니다.
원래 pow(T, int)
오버로드는 호출을 pow
인라인 곱셈 작업의 시퀀스로 언롤했습니다. 속도가 빠르지만 정확도가 훨씬 낮았습니다. 이 구현은 Visual Studio 2015 업데이트 1에서 제거되었습니다. 자세한 내용은 Visual Studio 2015 업데이트 1의 규칙 향상을 참조하세요.
기본적으로 이 함수의 전역 상태는 애플리케이션으로 범위가 지정됩니다. 이 동작을 변경하려면 CRT 전역 상태를 참조하세요.
요구 사항
루틴에서 반환된 값 | 필수 헤더(C) | 필수 헤더(C++) |
---|---|---|
pow , , powf powl |
<math.h> |
<math.h> 또는 <cmath> |
pow 매크로 |
<tgmath.h> |
호환성에 대한 자세한 내용은 호환성을 참조하세요.
예시
// crt_pow.c
#include <math.h>
#include <stdio.h>
int main( void )
{
double x = 2.0, y = 3.0, z;
z = pow( x, y );
printf( "%.1f to the power of %.1f is %.1f\n", x, y, z );
}
2.0 to the power of 3.0 is 8.0
참고 항목
수학 및 부동 소수점 지원
exp
, , expf
expl
log
, logf
, log10
log10f
sqrt
, , sqrtf
sqrtl
_CIpow