標籤:使用 os io for ar art cti amp
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");
}