欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS中原始值和引用值的儲存方式示例詳解

 更新時間:2018年03月23日 09:30:13   作者:心晴安夏  
原始值指的是代表原始數(shù)據(jù)類型的值,也叫基本數(shù)據(jù)類型,引用值指的是復(fù)合數(shù)據(jù)類型的值。接下來通過示例代碼給大家介紹JS中原始值和引用值的儲存方式,感興趣的朋友一起看看吧

在ECMAscript中,變量可以存放兩種類型的值,即原始值和引用值

  • 原始值指的是代表原始數(shù)據(jù)類型的值,也叫基本數(shù)據(jù)類型,包括:Number、Stirng、Boolean、Null、Underfined
  • 引用值指的是復(fù)合數(shù)據(jù)類型的值,包括:Object、Function、Array、Date、RegExp

根據(jù)數(shù)據(jù)類型不同,有的變量儲存在棧中,有的儲存在堆中。具體區(qū)別如下:

原始變量及他們的值儲存在棧中,當(dāng)把一個原始變量傳遞給另一個原始變量時,是把一個棧房間的東西復(fù)制到另一個棧房間,且這兩個原始變量互不影響。

引用值是把  引用變量的名稱儲存在棧中,但是把其實際對象儲存在堆中,且存在一個指針由變量名指向儲存在堆中的實際對象,當(dāng)把引用對象傳遞給另一個變量時,復(fù)制的其實是指向?qū)嶋H對象的指針, 此時 兩者指向的 是同一個數(shù)據(jù),若通過方法改變其中一個變量的值,則訪問另一個變量時,其值也會隨之加以改變;但若不是通過方法 而是通過 重新賦值  此時 相當(dāng)于 重新開了一個房間  該值的原指針改變  ,則另外一個 值 不會隨他的改變而改變。

看示例:

var a="hello";
var b=a;
a="world";
alert(a);//world
alert(b);//hello
var arr=[1,3];
arr1=arr;
arr.push(5);
alert(arr)//1,3,5
alert(arr1);//1,3,5
arr=[7,8];
alert(arr);//7,8
alert(arr1);//1,3,5

用圖來表示 結(jié)果如下:

原始變量的值互不影響,引用變量arr和arr1指向的為同一對象,所以當(dāng)對arr通過方法改變其值時(堆房間里的數(shù)據(jù)發(fā)生變化),訪問arr1的數(shù)據(jù)時就會訪問到改變后的對象


通過非方法來改變引用變量的值時,會為該引用變量重新創(chuàng)建一個堆房間,此時指針也會發(fā)生變化:

總結(jié):

Number、Stirng、Boolean、Null、Underfined這些基本數(shù)據(jù)類型,他們的值直接保存在棧中;

Object、Function、Array、Date、RegExp這些引用類型,他們的引用變量儲存在棧中,通過指針指向儲存在堆中的實際對象

以上所述是小編給大家介紹的JS中原始值和引用值的儲存方式示例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 淺析js的模塊化編寫 require.js

    淺析js的模塊化編寫 require.js

    requirejs是一個JavaScript文件和模塊加載器。requireJS允許你把你的javascript代碼獨(dú)立成文件和模塊,同時管理每個模塊間的依賴關(guān)系。本文主要對require.js的使用與工作原理進(jìn)行系統(tǒng)介紹。需要的朋友來看下吧
    2016-12-12
  • DOM和XMLHttpRequest對象的屬性和方法整理

    DOM和XMLHttpRequest對象的屬性和方法整理

    DOM和XMLHttpRequest對象的屬性和方法整理,注意是方便操作ajax的朋友
    2012-01-01
  • JavaScript中變量聲明有var和沒var的區(qū)別示例介紹

    JavaScript中變量聲明有var和沒var的區(qū)別示例介紹

    在函數(shù)內(nèi)部,有var和沒var聲明的變量是不一樣的。有var聲明的是局部變量,沒var的,聲明的全局變量,所以可以借此向外暴露接口東東
    2014-09-09
  • JsChart組件使用詳解

    JsChart組件使用詳解

    JSChart能夠在網(wǎng)頁上生成圖標(biāo),常用于統(tǒng)計信息,十分好用的一個JS組件。這篇文章主要介紹了JsChart組件使用詳解,需要的朋友可以參考下
    2018-03-03
  • ie6下png圖片背景不透明的解決辦法使用js實現(xiàn)

    ie6下png圖片背景不透明的解決辦法使用js實現(xiàn)

    我們時常在使用png圖片的時候,在ie6下發(fā)生背景不透明的問題,解決的方法實在是太多了,下面給大家介紹下一個js解決的方式,感興趣的朋友可以了解下的
    2013-01-01
  • 微信小程序scroll-view實現(xiàn)滾動穿透和阻止?jié)L動的方法

    微信小程序scroll-view實現(xiàn)滾動穿透和阻止?jié)L動的方法

    這篇文章主要介紹了微信小程序scroll-view實現(xiàn)滾動穿透和阻止?jié)L動的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • promise封裝wx.request的方法

    promise封裝wx.request的方法

    這篇文章主要介紹了promise封裝wx.request的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • JavaScript實現(xiàn)經(jīng)緯度轉(zhuǎn)換常用方法總結(jié)

    JavaScript實現(xiàn)經(jīng)緯度轉(zhuǎn)換常用方法總結(jié)

    WGS84坐標(biāo)系、GCJ02坐標(biāo)系、BD09坐標(biāo)系和Web 墨卡托投影坐標(biāo)系是我們常見的四個坐標(biāo)系。這篇文章為大家整理了這四個坐標(biāo)系之間相互轉(zhuǎn)換的方法,需要的可以參考一下
    2023-02-02
  • JavaScript函數(shù)this指向問題詳解

    JavaScript函數(shù)this指向問題詳解

    這篇文章主要為大家介紹了JavaScript函數(shù)this指向,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • JavaScript狀態(tài)模式及適配器模式使用講解

    JavaScript狀態(tài)模式及適配器模式使用講解

    這篇文章主要介紹了理解JavaScript中的狀態(tài)模式及適配器模式,適配器模式即Adapter Pattern,是作為兩個不兼容的接口之間的橋梁。這種類型的設(shè)計模式屬于結(jié)構(gòu)型模式,下文更多相關(guān)介紹需要的小伙伴可以參考一下
    2022-12-12

最新評論