这里聊聊Javascript的位运算,但是只聊几个(与运算、或运算、否运算)。
可能有人会说:位运算有那么多内容,怎么只讲这几个呢?那是因为:我一般避免把所有知识点搬上来,毕竟我不是做教科书的,只要在项目种遇到或者我学习到觉得需要记录下的才会动手写一下。如果需要学习其他的内容可以访问 " 阮一峰 " 的网站学习更多的内容,下面给出关于位运算的链接 http://javascript.ruanyifeng.com/grammar/operator.html 言归正传。
与运算:& 两个二进制位都是 1 则返回 1,否则(例如1&0,0&1)返回0
或运算:| 两个二进制位有一个是 1 则返回 1,否则(例如 0|0)返回0
否运算:~ 将一个二进制位变成相反值
从上面不难发现:位运算都是正对二进制的,优点是操作快,缺点是不直观。
另外:位运算只对整数起到作用,如果一个值不是整数,会自动转换为整数,再进行转换。
针对否运算学习一下:
显然3进行否运算之后是一个负数,负数在内存中采用补码的形式存在,此时求源码就是再次取补码并添上符号,也就是-4;简单记忆时可以进行否运算时,运算结果与运算子相加为-1;两次进行否运算得到数值本身,并且利用位运算对小数运算时,会自动转换为整数,两次取反即可得到整数,这是所有取整方法最快的一种。
针对以上特点,在项目中可以用到:
1.利用否运算对数值的向下取整
2.对多种情况下的组合的巧妙用法
这个说起来有点抽象,举例说明:假设用户进来的时候要检测用户:1.麦克风是否可用、2.扬声器是否可用、3.是否有显示器、4.是否有鼠标。当然了,这只是我的栗子。那么就有4种需求,组合起来有16种可能的情况,那么怎么判断这16中情况呢?这里就可以用到与运算了。
假设上诉的4种情况中,0表示否,1表示是。
那么就可以用二进制(转换后)来表示这四种情况了,假设全部都有,那么就可以是1111(对应:麦克风、扬声器、显示器、鼠标),那么我想知道是否有麦克风,只需要 15 & 8 ,结果是8,就是说2^3的这个3的位置是1,就是说是有麦克风的。
如果没有扬声器呢?那就是1011(11),那么就是11&4 结果是0,
这样就可以很方便的判断了。
好了,差不多总结的就这么多,学习的地方还有很多,学习使我快乐,哼。