_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 アーキテクチャ ヘッダー
_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 固有の仕様はここまで

関連項目

コンパイラの組み込み