Bitweises NICHT (~)

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

Der bitweise NICHT-Operator (~) gibt eine Zahl oder ein BigInt zurück, deren binäre Darstellung in jeder Bitposition, für die das entsprechende Bit des Operanden 0 ist, eine 1 und ansonsten eine 0 hat.

Probieren Sie es aus

const a = 5; // 00000000000000000000000000000101
const b = -3; // 11111111111111111111111111111101

console.log(~a); // 11111111111111111111111111111010
// Expected output: -6

console.log(~b); // 00000000000000000000000000000010
// Expected output: 2

Syntax

js
~x

Beschreibung

Der ~ Operator ist überladen für zwei Typen von Operanden: Zahl und BigInt. Für Zahlen gibt der Operator eine 32-Bit-Ganzzahl zurück. Für BigInts gibt der Operator ein BigInt zurück. Er zwingt den Operanden zuerst zu einem numerischen Wert und prüft dessen Typ. Er führt BigInt NICHT aus, wenn der Operand zu einem BigInt wird; andernfalls wird der Operand in eine 32-Bit-Ganzzahl umgewandelt und das bitweise NICHT für Zahlen durchgeführt.

Der Operator arbeitet mit den Bitdarstellungen der Operanden im Zweierkomplement. Der Operator wird auf jedes Bit angewendet, und das Ergebnis wird bitweise konstruiert.

Die Wahrheitstabelle für den NICHT-Operator lautet:

x NICHT x
0 1
1 0
 9 (base 10) = 00000000000000000000000000001001 (base 2)
               --------------------------------
~9 (base 10) = 11111111111111111111111111110110 (base 2) = -10 (base 10)

Das bitweise NICHT einer beliebigen 32-Bit-Ganzzahl x ergibt -(x + 1). Zum Beispiel ergibt ~-5 4.

Zahlen mit mehr als 32 Bits verlieren ihre höchstwertigen Bits. Zum Beispiel wird die folgende Ganzzahl mit mehr als 32 Bits in eine 32-Bit-Ganzzahl umgewandelt:

Before: 11100110111110100000000000000110000000000001
After:              10100000000000000110000000000001

Warnung: Sie werden möglicherweise Personen sehen, die ~~ verwenden, um Zahlen auf Ganzzahlen zu kürzen. Ein zweimaliges Anwenden des bitweisen NICHT-Operators auf eine beliebige Zahl x gibt x als 32-Bit-Ganzzahl zurück, was zusätzlich führende Bits für Zahlen außerhalb des Bereichs von -2147483648 bis 2147483647 entfernt. Verwenden Sie stattdessen Math.trunc().

Für BigInts gibt es keine Kürzung. Konzeptuell können Sie positive BigInts als eine unendliche Anzahl führender 0-Bits verstehen und negative BigInts als eine unendliche Anzahl führender 1-Bits.

Beispiele

Verwendung von bitweisem NICHT

js
~0; // -1
~-1; // 0
~1; // -2

~0n; // -1n
~4294967295n; // -4294967296n

Spezifikationen

Specification
ECMAScript® 2026 Language Specification
# sec-bitwise-not-operator

Browser-Kompatibilität

Siehe auch