DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> javascript的字符串按引用復制和傳遞,按值來比較介紹與應用
javascript的字符串按引用復制和傳遞,按值來比較介紹與應用
編輯:關於JavaScript     
按值和按引用的比較
Numbers 和 Boolean 類型的值 (true 和 false) 是按值來復制、傳遞和比較的。當按值復制或傳遞時,將在計算機內存中分配一塊空間並將原值復制到其中。然後,即使更改原來的值,也不會影響所復制的值(反過來也一樣),因為這兩個值是獨立的實體。

對象、數組以及函數是按引用來復制、傳遞和比較的。 當按地址復制或傳遞時,實際是創建一個指向原始項的指針,然後就像拷貝一樣來使用該指針。如果隨後更改原始項,則將同時更改原始項和復制項(反過來也一樣)。實際上只有一個實體;“復本”並不是一個真正的復本,而只是該數據的又一個引用。

當按引用比較時,要想比較成功,兩個變量必須參照完全相同的實體。例如,兩個不同的 Array 對象即使包含相同的元素也將比較為不相等。要想比較成功,其中一個變量必須為另一個的參考。要想檢查兩個數組是否包含了相同的元素,比較 toString() 方法的結果。

最後,字符串是按引用復制和傳遞的,但是是按值來比較的。請注意,假如有兩個 String 對象(用 new String("something") 創建的),按引用比較它們,但是,如果其中一個或者兩者都是字符串值的話,按值比較它們。

字符串是按引用復制和傳遞的,但是是按值來比較的。請注意,假如有兩個 String 對象(用 new String("something") 創建的),按引用比較它們,但是,如果其中一個或者兩者都是字符串值的話,按值比較它們。
復制代碼 代碼如下:
var str1="aa";
var str2=new String("aa");
var str3=str2;
function test(p){
var str4=p;
console.log(str4===str2);
}
console.log(str1===str2); //false
console.log(str3===str2); //true
test(str1);//false
test(str2);//true
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved