다음을 통해 공유


__emul, __emulu

Microsoft 전용

어떻게 32 비트 정수를 저장할 수 있는 오버플로 곱하기를 수행 합니다.

__int64 __emul(
   int a,
   int b
);
unsigned __int64 __emulu(
   unsigned int a,
   unsigned int b
);

매개 변수

  • [in] a
    첫 번째 정수 피연산자의 곱입니다.

  • [in] b
    두 번째 정수 피연산자의 곱입니다.

반환 값

결과 곱입니다.

요구 사항

내장

아키텍처

__emul

x 86x64

__emulu

x 86x64

헤더 파일 <intrin.h>

설명

__emul두 개의 32 비트 부호 있는 값을 사용 하는 64 비트 부호 있는 정수 값으로 곱하기의 결과 반환 합니다.

__emulu두 개의 32 비트 부호 없는 정수 값을 사용 하 고는 64 비트 부호 없는 정수 값으로 곱하기의 결과 반환 합니다.

예제

// emul.cpp
// compile with: /EHsc
// processor: x86, x64
#include <iostream>
#include <intrin.h>
using namespace std;

#pragma intrinsic(__emul)
#pragma intrinsic(__emulu)

int main()
{
   int a = -268435456; 
   int b = 2; 

   __int64 result = __emul(a, b);

   cout << a << " * " << b << " = " << result << endl;

   unsigned int ua = 0xFFFFFFFF; // Dec value: 4294967295
   unsigned int ub = 0xF000000;  // Dec value: 251658240

   unsigned __int64 uresult = __emulu(ua, ub);

   cout << ua << " * " << ub << " = " << uresult << endl;

}

Output

-268435456 * 2 = -536870912
4294967295 * 251658240 = 1080863910317260800

참고 항목

참조

컴파일러 내장 함수