_umul128
Microsoft 固有の仕様
最初の 2 つの引数で渡された 2 つの 64 ビット符号なし整数を乗算し、その積の上位 64 ビットを HighProduct
の指す 64 ビットの符号なし整数に格納して、積の下位 64 ビットを返します。
構文
unsigned __int64 _umul128(
unsigned __int64 Multiplier,
unsigned __int64 Multiplicand,
unsigned __int64 *HighProduct
);
パラメーター
乗数
[in] 乗算する最初の 64 ビット整数。
Multiplicand
[in] 乗算する 2 番目の 64 ビット整数。
HighProduct
[out] 積の上位 64 ビット。
戻り値
積の下位 64 ビット。
要件
Intrinsic | Architecture | ヘッダー |
---|---|---|
_umul128 |
x64 | <intrin.h> |
例
// umul128.c
// processor: x64
#include <stdio.h>
#include <intrin.h>
#pragma intrinsic(_umul128)
int main()
{
unsigned __int64 a = 0x0fffffffffffffffI64;
unsigned __int64 b = 0xf0000000I64;
unsigned __int64 c, d;
d = _umul128(a, b, &c);
printf_s("%#I64x * %#I64x = %#I64x%I64x\n", a, b, c, d);
}
0xfffffffffffffff * 0xf0000000 = 0xeffffffffffffff10000000
Microsoft 固有の仕様はここまで