按位非 (~)

Baseline 已广泛支持

此特性已相当成熟,可在许多设备和浏览器版本上使用。自 ⁨2015 年 7 月⁩以来,各浏览器均已提供此特性。

按位非 (~) 运算符返回一个数字或 BigInt,其二进制表示中,操作数对应位为 0 的位位置上为 1,否则为 0

试一试

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

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

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

语法

js
~x

描述

~ 运算符针对两种类型的操作数进行了重载:数字和 BigInt。对于数字,该运算符返回一个 32 位整数。对于 BigInt,该运算符返回一个 BigInt。它首先将操作数强制转换为数值并测试其类型。如果操作数成为 BigInt,则执行 BigInt 按位非操作;否则,它会将操作数转换为32 位整数并执行数字按位非操作。

该运算符在操作数的二进制补码位表示上进行操作。该运算符应用于每个位,并按位构造结果。

NOT 运算的真值表是

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

对任何 32 位整数 x 进行按位非操作都会得到 -(x + 1)。例如,~-5 得到 4

超过 32 位的数字将丢弃其最高有效位。例如,以下超过 32 位的整数将被转换为 32 位整数

Before: 11100110111110100000000000000110000000000001
After:              10100000000000000110000000000001

警告:你可能会看到人们使用 ~~ 来将数字截断为整数。对任何数字 x 两次进行按位非操作会返回转换为 32 位整数的 x,这还会移除超出 -2147483648 到 2147483647 范围的数字的前导位。请改用 Math.trunc()

对于 BigInt,没有截断。从概念上讲,将正 BigInt 理解为具有无限数量的前导 0 位,将负 BigInt 理解为具有无限数量的前导 1 位。

示例

使用按位非

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

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

规范

规范
ECMAScript® 2026 语言规范
# sec-bitwise-not-operator

浏览器兼容性

另见