Freigeben über


__shiftleft128

Microsoft-spezifisch

Verschiebt eine 128-Bit-Menge, dargestellt als zwei 64-Bit-Mengen LowPart und HighPart, um eine angegebene Anzahl von Bits, die durch Shift definiert wird, nach links und gibt die unteren 64 Bits des Ergebnisses zurück.

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

Parameter

  • [in] LowPart
    Die unteren 64 Bits der zu verschiebenden 128-Bit-Menge.

  • [in] HighPart
    Die oberen 64 Bits der zu verschiebenden 128-Bit-Menge.

  • [in] Shift
    Die Anzahl der zu verschiebenden Bits.

Rückgabewert

Die oberen 64 Bits des Ergebnisses.

Anforderungen

Systemintern

Architektur

__shiftleft128

x64

Headerdatei <intrin.h>

Hinweise

Der Shift-Wert ist immer modulo 64. So verschiebt z. B. beim Aufrufen von __shiftleft128(1, 0, 64) die Funktion die 0-Bits des unteren Teils nach links und gibt einen oberen Teil von 0 und nicht von 1 zurück, wie man annehmen könnte.

Beispiel

// 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);  
}
  

Siehe auch

Referenz

__shiftright128

Intrinsische Compilerfunktionen