__emul、__emulu
Microsoft 固有の仕様
32 ビット整数が保持できる値をオーバーフローする乗算を実行します。
構文
__int64 __emul(
int a,
int b
);
unsigned __int64 __emulu(
unsigned int a,
unsigned int b
);
パラメーター
a
[in]乗算の最初の整数オペランド。
b
[in]乗算の 2 番目の整数オペランド。
戻り値
乗算の結果。
要件
Intrinsic | Architecture |
---|---|
__emul |
x86、x64 |
__emulu |
x86、x64 |
ヘッダー ファイル<intrin.h>
解説
__emul
は 2 つの 32 ビット符号付き値を受け取り、乗算の結果を 64 ビット符号付き整数値として返します。
__emulu
は 2 つの 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;
}
出力
-268435456 * 2 = -536870912
4294967295 * 251658240 = 1080863910317260800
Microsoft 固有の仕様はここまで