__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 固有の仕様はここまで