20个你不得不知道的js位运算用法

 更新时间:2023年12月04日 08:24:52   作者:慕仲卿  
位运算,那些看似晦涩但又蕴含无限魔力的数字魔术,在JavaScript开发中扮演了默默无闻却又至关重要的角色,本文介绍多个js位运算的使用场景,阐述在JavaScript中,如何巧妙运用位运算实现效率的提升和算法的优化,需要的朋友可以参考下

位运算的奇妙应用

1. 乘法和除法运算

位运算可实现乘法和除法的简易版本,如num << 1(乘2),num >> 1(除2)。

let num = 4;
let multiplied = num << 1; // 结果为8
let divided = num >> 1; // 结果为2

2. 判断奇偶性

通过和1的与运算检查最低位,判断数值的奇偶性。

let num = 7;
let isOdd = num & 1; // 结果为1,奇数

3. 交换变量

利用异或运算交换两个变量的值,无需额外空间。

let a = 2, b = 3;
a ^= b;
b ^= a;
a ^= b; // a === 3, b === 2

4. 取绝对值

使用位运算取整数的绝对值。

let num = -6;
let abs = (num ^ (num >> 31)) - (num >> 31); // 结果为6

5. 检测数值是否为2的幂

检测一个数是否为2的幂可以通过判断其是否只有一个位是1。

let num = 8;
let isPowerOfTwo = (num & (num - 1)) === 0; // 结果为true

6. 轮转位

通过位运算实现位的循环,左轮或右轮。

let num = 21; // (10101)
num = (num >> 3) | (num << (32 - 3)); // 右轮转3位

7. 快速计算

快速计算n2n,等同于n << n

let n = 5;
let result = 5 << 5; // 结果为160

8. 掩码运算

使用掩码进行位运算,快速提取片段中的信息。

// 使用掩码获取RGB颜色的红色分量
let color = 0xffeEDC;
let red = (color & 0xff0000) >> 16;

9. 快速杜敏运算

利用异或运算实现一次杜敏运算,即不改变其他位的情况下翻转特定位。

let flags = 5; // (101)
let mask = 2; // (010)
flags ^= mask; // 结果为7 (111)

10. 利用掩码来设置位

设置特定位为1而不影响其他位。

let num = 4; // (100)
num |= 2; // 结果为6 (110)

11. 利用掩码来清零位

通过与运算将特定位清零。

let num = 15; // (1111)
num &= ~8; // 结果为7 (0111)

12. 低效的按位非运算

通过按位非运算实现变量值减1。

let num = 10;
num = ~num; // 结果为-11

13. 条件无分支

实现条件判断无需if语句,适用于某些性能敏感的场合。

let a = 10, b = 20;
let max = a - ((a - b) & ((a - b) >> 31));

14. 检测位是否被置位

检测某一位是否为1。

let flag = 8; // (1000)
let isSet = flag & (1 << 3); // 结果为8,表示第3位被置位

15. 浮点数转整数

通过零填充右移将浮点数向下取整。

let floatNum = 3.9;
let intNum = floatNum >> 0; // 结果为3

16. RGB颜色混合

通过位运算实现简易的RGB颜色值混合。

let color1 = 0xff00ff, color2 = 0x00ff00;
let mixed = (color1 & color2) + (((color1 ^ color2) & 0xfefefe) >> 1);

17. 模2^n取余

利用位运算快速取模2的幂。

let num = 19;
let mod = num & (8 - 1); // 结果为3,相当于19 % 8

18. 实现布尔数组

使用位运算实现高效的布尔数组,节约空间。

let array = 0;
array |= 1 << index; // 设置index位置为1
let isTrue = (array & (1 << index)) !== 0; // 检测index位置是否为1

19. 求相反数

通过位运算获取一个数的相反数。

let num = -48;
let opposite = ~num + 1; // 结果为48

20.计算汉明权重

计算一个数二进制表示中1的个数(汉明权重)。

let num = 13; // (1101)
let count = 0;
while(num) {
    count++;
    num &= num - 1; // 清除最低位的1
}
// 结果 count 为3

以上就是20个你不得不知道的js位运算用法的详细内容,更多关于js位运算用法的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript判断元素是否在可视区域的三种方法

    JavaScript判断元素是否在可视区域的三种方法

    这这篇文章给大家总结了JavaScript判断元素是否在可视区域的三种方法,getBoundingClientRect,IntersectionObserver和offsetTop、scrollTop这三种方法,文中通过代码示例给大家介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • javascript二维数组和对象的深拷贝与浅拷贝实例分析

    javascript二维数组和对象的深拷贝与浅拷贝实例分析

    这篇文章主要介绍了javascript二维数组和对象的深拷贝与浅拷贝,结合实例形式分析了JavaScript针对数组与对象的深拷贝及浅拷贝相关操作技巧,需要的朋友可以参考下
    2019-10-10
  • 微信小程序实现竖排slider效果

    微信小程序实现竖排slider效果

    这篇文章主要为大家详细介绍了微信小程序实现竖排slider效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • Webpack学习之动态import原理及源码分析

    Webpack学习之动态import原理及源码分析

    这篇文章主要为大家介绍了Webpack学习之动态import原理及源码分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 微信小程序传值以及获取值方法的详解

    微信小程序传值以及获取值方法的详解

    这篇文章主要介绍了微信小程序传值以及获取值方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • 基于Bootstrap的Metronic框架实现页面链接收藏夹功能

    基于Bootstrap的Metronic框架实现页面链接收藏夹功能

    本文给大家介绍基于Metronic的Bootstrap开发框架实现页面链接收藏夹功能,非常不错,具有参考借鉴价值,感兴趣的朋友一起学习吧
    2016-08-08
  • 解决jquery插件冲突的问题

    解决jquery插件冲突的问题

    本篇文章主要是对解决jquery插件冲突的方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • js实现图片放大并跟随鼠标移动特效

    js实现图片放大并跟随鼠标移动特效

    这篇文章主要为大家详细介绍了js实现图片放大并跟随鼠标移动特效,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • 一文入门Webpack文件指纹

    一文入门Webpack文件指纹

    文件指纹是文件打包后输出的文件名的后缀,通常用来做一些文件的版本管理,文中给大家提到了几种文件指纹的设置用法,对Webpack文件指纹相关知识感兴趣的朋友一起看看吧
    2022-02-02
  • js获取内联样式的方法

    js获取内联样式的方法

    这篇文章主要介绍了js获取内联样式的方法,针对标准浏览器与IE浏览器进行不同的判断与获取,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01

最新评论