1.ECMAScript中所有数都以IEEE-754 64位格式存储,但位操作符不直接操作64位的值.是先64位转换成32位的整数,再操作,得到结果再转成64位.
2.首位是符号位.之后的31位代表整数的值.
3.用toString(2)打印二进制,得到的是被处理过的二进制.
4.按位非(NOT)~,数转成二进制,取反.相当于把操作数先变负再-1;
5.按位与(AND)&,两个数的二进制,有一个0结果就是0,两个都是1才为1.
6.按位或(OR)|,有一个1结果为1,都是0才为0.
7.按位异或(XOR)^,相同为0,不同为1;
8.==和!=,先转换再比较.===和!==只比较不转换
9.label配合for,等循环语句使用.用来跳出或结束.
10.函数中隐藏的argument属性,可以重写功能.但JS没有重载.
读到位非时突然想测试一下性能.
自己的随笔测试小程序.
var arr1 = new Array();
var arr2 = new Array();
var num = 0;
function testNOT() {
var str = "This is the letter sigma";
var query = "sigma";
do {
var timeStart1 = new Date();
for(var i=0; i<10000000; i++) {
str.indexOf(query);
}
var timeEnd1 = new Date();
var result1 = timeEnd1 - timeStart1;
arr1.push(result1);
//console.log("str1.indexOf(query):" + (timeEnd1 - timeStart1) + "ms");
var timeStart2 = new Date();
for(var i=0; i<10000000; i++) {
~str.indexOf(query);
}
var timeEnd2 = new Date();
var result2 = timeEnd2 - timeStart2;
arr2.push(result2);
//console.log("~str1.indexOf(query):" + (timeEnd2 - timeStart2) + "ms");
document.write("普通写法:"+ result1+"ms");
document.write("位非写法:"+ result2+"ms"+"<br>");
document.write("=================================<br>");
num++;
}
while(num<10);
}
function arrResult() {
var tempArr1 = 0;
var tempArr2 = 0;
var arr1Length = arr1.length;
var arr2Length = arr2.length;
for(var i=0; i<arr1Length; i++) {
tempArr1 = arr1[i] + tempArr1;
//console.log(tempArr1);
}
var arr1Time = tempArr1/arr1Length;
document.write("普通写法的"+num+"次的平均用时:"+arr1Time+"ms<br>");
for(var i=0; i<arr2Length; i++) {
tempArr2 = tempArr2 + arr2[i];
}
var arr2Time = tempArr2/arr2Length;
document.write("位非写法的"+num+"次的平均用时:"+arr2Time+"ms<br>");
var contrastResult = arr1Time-arr2Time;
document.write("位非写法比普通写法快了:"+contrastResult+"ms");
}
<JS高级程序设计3>_PART3,布布扣,bubuko.com
原文:http://www.cnblogs.com/chensen/p/3920893.html