__emul, __emulu
Microsoft 전용
32비트 정수가 보유할 수 있는 것을 오버플로하는 곱셈을 수행합니다.
구문
__int64 __emul(
int a,
int b
);
unsigned __int64 __emulu(
unsigned int a,
unsigned int b
);
매개 변수
a
[in] 곱하기의 첫 번째 정수 피연산자입니다.
b
[in] 곱하기의 두 번째 정수 피연산자입니다.
반환 값
곱하기 결과입니다.
요구 사항
Intrinsic | 아키텍처 |
---|---|
__emul |
x86, x64 |
__emulu |
x86, x64 |
헤더 파일<intrin.h>
설명
__emul
는 두 개의 32비트 부속 값을 사용하고 곱하기 결과를 64비트 부속 정수 값으로 반환합니다.
__emulu
는 부호 없는 32비트 정수 값 2개를 사용하고 곱하기 결과를 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;
}
출력
-268435456 * 2 = -536870912
4294967295 * 251658240 = 1080863910317260800
Microsoft 전용 종료