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

Javascript數(shù)組中push方法用法分析

 更新時間:2016年10月31日 11:26:58   作者:梁龍飛  
這篇文章主要介紹了Javascript數(shù)組中push方法用法,結合實例形式分析了javascript中push方法的原理、使用方法與相關注意事項,需要的朋友可以參考下

本文實例講述了Javascript數(shù)組中push方法用法。分享給大家供大家參考,具體如下:

看下面代碼:

var o = {
  1:'a'
  ,2:'b'
  ,length:2
  ,push:Array.prototype.push
};
o.push('c');

Q:o現(xiàn)在內(nèi)部的值是什么樣子?

我的第一反應是排斥,為什么要研究不合理情況下【解釋引擎】的行為?但是這種推論有時候又很吸引人,于是我回來的時候仔細思考了下,發(fā)現(xiàn)其實很簡單。

對于push這個方法,我條件反射地想到的就是棧,【數(shù)據(jù)結構的經(jīng)典?!恐袎簵:蛷棗2僮饕罁?jù)的都是棧頂指針,棧頂指針始終指向棧頂,意味著它會因為壓彈棧而自動增減。在javascript中的數(shù)組中這個指針就是length。所以在上面的代碼中,o.push('c')就是o.2 = 'c'(當然o.2不能直接訪問,這只是偽代碼),所以代碼執(zhí)行完o中數(shù)據(jù)如下:

{
  1:'a'
  ,2:'c'
  ,length:3 //push操作=>length+1
  ,push:Array.prototype.push
}

補充說明:

JavaScript中,萬物皆對象,而javascript的對象與強類型的對象有一些不同的地方,可以理解成就是一組鍵值對的集合。其array類型也不例外,它的下標訪問就是鍵訪問(不過它的鍵都是自然數(shù)),在上面的例子中賦值給a的對象字面量實際模擬了一個數(shù)組(一個下標從1開始的數(shù)組)——當然只有部分數(shù)組的特性,比如真實的數(shù)組在進行鍵訪問的時候,會根據(jù)length進行越界檢查。

只要知道push的位置依據(jù)的是length就可以了,下面種種看似奇怪的現(xiàn)象都好理解:

//1.length不存在,引擎置為0
var o = {
  '1':'a'
  ,'2':'b'
  ,push:Array.prototype.push
};
o.push('c');//c {0:'c',1:'a',2:'b',...}
//2.length為負值,這是個有趣的問題,涉及到原碼反碼和補碼【1】
var o = {
  '1':'a'
  ,'2':'b'
  ,length:-1
  ,push:Array.prototype.push
};
o.push('c');//c {1:'a',2:'b',4294967295:'c',length:4294967296,...}
//3.length為字符或對象
var o = {
  1:'a'
  ,2:'b'
  ,length:'A'
  ,push:Array.prototype.push
};
o.push('c');//c {0:'c',1:'a',2:'b',length:1,...}我還以為js解釋器會把A轉換成ASCII碼來給length賦值呢,終于看到了javascript的自由還是有節(jié)操的

計算機中數(shù)值都是以補碼方式存儲的,為了方便運算,-1的補碼與4294967295補碼一樣,根據(jù)length的語義,此處是無符號數(shù)

[-1]補 = 1111 1111 1111 1111 1111 1111 1111 1111 =  [4294967295]補  = 1111 1111 1111 1111 1111 1111 1111 1111

所以這樣我們接差對2中的o壓入一個對象,key取的是4294967296,但是數(shù)組的最大長度限制為4294967296,也就是說下標只能取到4294967295,只會取到32位——對于4294967296 = 1 0000 0000 0000 0000 0000 0000 0000 0000 取后32位,就變成了0,所以此次push的位置是0。

更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)組操作技巧總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript數(shù)學運算用法總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》及《JavaScript錯誤與調(diào)試技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • js獲取Get值的方法

    js獲取Get值的方法

    這篇文章主要介紹了js獲取Get值的方法,涉及javascript正則及頁面參數(shù)操作相關技巧,需要的朋友可以參考下
    2016-09-09
  • javaScript 利用閉包模擬對象的私有屬性

    javaScript 利用閉包模擬對象的私有屬性

    JavaScript缺少塊級作用域,沒有private修飾符,但它具有函數(shù)作用域。作用域的好處是內(nèi)部函數(shù)可以訪問它們的外部函數(shù)的參數(shù)和變量(除了this和argument
    2011-12-12
  • js計算兩個日期間的天數(shù)月的實例代碼

    js計算兩個日期間的天數(shù)月的實例代碼

    本文通過實例代碼給大家介紹了基于js計算兩個日期間的天數(shù)月,文中還通過一段代碼給大家簡單說明了js計算兩個日期差的方法,感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • Javascript模塊模式分析

    Javascript模塊模式分析

    javascritp模式講解全局變量是魔鬼。在YUI中,我們僅用兩個全局變量:YAHOO和YAHOO_config。YUI的一切都是使用YAHOO對象級的成員或這個成員作用域內(nèi)的變量。我們建議在你的應用程序也使用類似的規(guī)則。
    2008-05-05
  • JS繼承與閉包及JS實現(xiàn)繼承的三種方式

    JS繼承與閉包及JS實現(xiàn)繼承的三種方式

    大家都知道,面向對象的三大特征——封裝、繼承、多態(tài)。下面通過本文給大家介紹JS繼承與閉包及JS實現(xiàn)繼承的三種方式,感興趣的朋友一起看看吧
    2017-10-10
  • Javascript模擬實現(xiàn)new原理解析

    Javascript模擬實現(xiàn)new原理解析

    這篇文章主要介紹了Javascript模擬實現(xiàn)new原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03
  • 表單元素值獲取方式js及java方式的簡單實例

    表單元素值獲取方式js及java方式的簡單實例

    下面小編就為大家?guī)硪黄韱卧刂但@取方式js及java方式的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • bootstrap laydate日期組件使用詳解

    bootstrap laydate日期組件使用詳解

    這篇文章主要為大家詳細介紹了bootstrap laydate日期組件使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • js正則表達式驗證表單【完整版】

    js正則表達式驗證表單【完整版】

    本篇文章主要介紹了js正則表達式驗證表單的實例,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • javascript typeof的用法與typeof運算符介紹[詳細]

    javascript typeof的用法與typeof運算符介紹[詳細]

    下面是對于typeof運算符的詳細介紹跟typeof的一些用法,分析,學習typeof的朋友,看完了,這篇應該能有所收獲。
    2008-10-10

最新評論