다음을 통해 공유


pow, , powfpowl

xy승 값을 계산합니다.

구문

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
지수입니다.

반환 값

xy의 값을 반환합니다. 오버플로 또는 언더플로 시 오류 메시지는 인쇄되지 않습니다.

및 값 xy 의 반환 값 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, , powfpowl <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, , expfexpl
log, logf, log10log10f
sqrt, , sqrtfsqrtl
_CIpow