Bitwise amp; Operator in Javascript(Java脚本中的位运算符(A))
本文介绍了Java脚本中的位运算符(&A)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我不明白为什么只有Num1会打印输出,而它们都应该打印输出。我是不是错过了什么?
var num1 = 0x200127;
var num2 = 0x200124;
if(num1 & 0x100 == 0x100){
console.log("num1: " + (num1 & 0x100 ) );
}
if(num2 & 0x100 == 0x100){
console.log("num2: " + (num2 & 0x100 ) );
}
推荐答案
这是操作顺序问题。 作为参考,请查看table of JavaScript operator precedence。
==的精度为10,而&的精度为9,因此==首先求值。
所以您的代码实际上是在计算:
num & (0x100 == 0x100)
相当于:
num & true
num1被输出,而num2不是因为:
0x200127 & true == 1 (true)
0x200124 & true == 0 (false)
请尝试将按位运算放在括号中,因为grouping operator是所有运算中优先级最高的。
if((num1 & 0x100) == 0x100){
console.log("num1: " + (num1 & 0x100 ) );
}
if((num2 & 0x100) == 0x100){
console.log("num2: " + (num2 & 0x100 ) );
}
在下面进行测试:
var num1 = 0x200127,
num2 = 0x200124,
output = document.getElementById('output');
if ((num1 & 0x100) == 0x100) {
output.innerHTML += "<p>num1: " + (num1 & 0x100) + "</p>";
}
if ((num2 & 0x100) == 0x100) {
output.innerHTML += "<p>num2: " + (num2 & 0x100) + "</p>";
}
<div id="output"></div>
这篇关于Java脚本中的位运算符(&A)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
编程基础网
本文标题为:Java脚本中的位运算符(&A)
基础教程推荐
猜你喜欢
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- HTML5 画布调整为父级 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- 从快速中间件中排除路由 2022-01-01
