次の方法で共有


__shiftleft128

Microsoft 固有の仕様

64 ビットの 2 つの数 LowPart および HighPart で表される 128 ビットの数を、Shift で指定されたビット数だけ左にシフトし、結果の上位 64 ビットを返します。

構文

unsigned __int64 __shiftleft128(
   unsigned __int64 LowPart,
   unsigned __int64 HighPart,
   unsigned char Shift
);

パラメーター

LowPart
[in] シフトする 128 ビット数の下位 64 ビット。

HighPart
[in] シフトする 128 ビット数の上位 64 ビット。

Shift
[in] シフトするビット数。

戻り値

結果の上位 64 ビット。

要件

Intrinsic Architecture
__shiftleft128 x64

ヘッダー ファイル<intrin.h>

解説

Shift の値は常にモジュロ 64 であるため、__shiftleft128(1, 0, 64) を呼び出すと、関数によって下位部分が 0 ビット左にシフトされ、予期される 1 ではなく、0 の上位部分が返されます。

// shiftleft128.c
// processor: IPF, x64
#include <stdio.h>
#include <intrin.h>

#pragma intrinsic (__shiftleft128, __shiftright128)

int main()
{
    unsigned __int64 i = 0x1I64;
    unsigned __int64 j = 0x10I64;
    unsigned __int64 ResultLowPart;
    unsigned __int64 ResultHighPart;

    ResultLowPart = i << 1;
    ResultHighPart = __shiftleft128(i, j, 1);

    // concatenate the low and high parts padded with 0's
    // to display correct hexadecimal 128 bit values
    printf_s("0x%02I64x%016I64x << 1 = 0x%02I64x%016I64x\n",
             j, i, ResultHighPart, ResultLowPart);

    ResultHighPart = j >> 1;
    ResultLowPart = __shiftright128(i, j, 1);

    printf_s("0x%02I64x%016I64x >> 1 = 0x%02I64x%016I64x\n",
             j, i, ResultHighPart, ResultLowPart);
}
0x100000000000000001 << 1 = 0x200000000000000002
0x100000000000000001 >> 1 = 0x080000000000000000

Microsoft 固有の仕様はここまで

関連項目

__shiftright128
コンパイラの組み込み