时间能淡忘一切,只要时间够久,即使是曾经最深刻的记忆。
按位取反,涉及到补码等计算机知识,大学时学过,现在提起原码、反码、补码,依稀有点影响,但具体的已淡忘的不留一丝痕迹。借助网络的力量,再次来记忆一遍。
在 js 中是通过 ~
符号进行按位取反操作的。具体的规则如下:
- 原码:10进制变2进制,8位,并标明符号位。0正数,1负数,最左一位为最高位。
- 反码:按位取反
- 补码:除符号位不变,其他位取反
- 补码修复:最高位为正,末尾 -1 修复;最高位为负,末尾 +1 修复
- 转换:2进制变10进制
补充:为什么要有补码及补码修正?因为计算机中减法是通过加一个负数处理的,而负数又是通过补码保存的。目的就是为了统一加法减法。原码:
举例:
~9 结果:-10
原码:00001001 反码:11110110 补码:10001001 修正:10001010 1是负,加1修正 转换:-0008020 -> 10~-9 结果:8
原码:10001001 反码:01110110 补码:00001001 修正:00001000 0是正,减1修正 转换:+0008000 -> 8在 js 中运用:位运算的效率高于符号运算
let str = 'wwr23';if (str.indexOf('2') > -1)) {// 存在 }// 优化替换,原理 ~-1 // 0 ~0 // -1 ~1//-2 ~2//-3 只要不为0都为trueif (~str.indexOf('2'))) {// 存在}