首頁 >web前端 >js教程 >JavaScript 中的不同資料型別。

JavaScript 中的不同資料型別。

Barbara Streisand
Barbara Streisand原創
2025-01-15 06:36:46315瀏覽

Different Data types in JavaScript.

JavaScript 中有不同的資料型態。

  • 原始型別:字串、數字、布林值、未定義、null、符號和 ​​bigint。

  • 引用型別:物件、函數、陣列。


原始型

原始型別是 JavaScript 中最基本的資料型別。它們是一成不變的。這意味著一旦創建了原始值,就無法更改。不要將此與重新分配變數混淆。重新分配變數與更改基本類型的值不同。

重新分配就可以了? ?

let str = "hello";
str = "Hello"; // str -> "Hello"

在此範例中,我們將變數 str 重新指派給新值。這完全沒問題。

相同的值在記憶體中也是相同的

let str1 = "hello";
let str2 = "hello";

這裡有兩個變量,str1 和 str2,它們具有相同的值。在 JavaScript 中,如果兩個原始值相同,則它們相等。它們是相等的,因為在底層,兩個變數都指向相同的記憶體位置。

相同的字串不會在記憶體中重新建立。它們僅在記憶體中儲存一次。 JavaScript 工程師使用一種名為字串駐留的技術來最佳化記憶體使用。這種技術也用於數字。

原始型別是不可變的

let str = "hello";
str[0] = "H"; // str -> "hello"

字串一旦建立就無法變更。在此範例中,我們嘗試將字串 str 的第一個字元變更為“H”。這行不通。字串 str 將保持不變。原始型別是不可變的。

如果您需要建立一個新字串,您可以明確地這樣做:

let newStr = "H" + str.slice(1); // newStr -> "Hello"

參考類型

引用型別是可變的。這意味著您可以更改引用類型的值。它們被稱為引用類型,以強調它們作為引用存儲在記憶體中。雖然字串也儲存為引用,但它們是不可變的,並使用 駐留 技術來避免在記憶體中重新建立相同的值。

物件是在記憶體中新建立的

let obj1 = { name: "John" };
let obj2 = { name: "John" };

這裡,obj1和obj2是兩個不同的物件。它們儲存在不同的記憶體位置。儘管它們具有相同的屬性和值,但它們並不相等,因為物件是透過引用而不是值進行比較的。

改變具有相同引用的對象

let obj1 = { name: "John" };
let obj2 = obj1;

這裡,obj1和obj2是同一個物件。兩個變數都指向相同的記憶體位置。如果您更改此位置的值,它將反映在兩個變數中。

例子

obj2.name = "Jane"; // obj1 -> { name: "Jane" }, obj2 -> { name: "Jane" }

想像一下它在記憶體中的樣子:

Memory location 1: { name: "John" }

obj1 -> Memory location 1
obj2 -> Memory location 1

更新後:

let str = "hello";
str = "Hello"; // str -> "Hello"

我們更新了記憶體位置 1 中的值。很自然,obj1 和 obj2 都會反映此更改,因為它們都引用相同的記憶體位置。


結論

原始類型是不可變的,並透過字串駐留等技術針對記憶體使用進行了最佳化,而引用類型透過可變性和共享引用提供了更大的靈活性。透過掌握這些概念,您可以更好地預測和控製程式碼的行為,從而建立更健壯且可維護的應用程式。

以上是JavaScript 中的不同資料型別。的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn