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