按位非 (~)
按位非 (~) 运算符返回一个数字或 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 |
浏览器兼容性
加载中…