JavaScript裝箱及拆箱boxing及unBoxing用法解析
首先我們來看看這段代碼
var s1 = 'abc';var s2 = s1.indexOf('a')
s1 是個(gè) string 啊,怎么會(huì)有 indexOf() 方法呢?
這里就涉及到了 JavaScript 中的裝箱與拆箱的概念了
裝箱:把基本數(shù)據(jù)類型轉(zhuǎn)化為對(duì)應(yīng)的引用數(shù)據(jù)類型的操作
在《javascript高級(jí)程序設(shè)計(jì)》中有這樣一句話:
每當(dāng)讀取一個(gè)基本類型的時(shí)候,后臺(tái)就會(huì)創(chuàng)建一個(gè)對(duì)應(yīng)的基本包裝類型對(duì)象,從而讓我們能夠調(diào)用一些方法來操作這些數(shù)據(jù)。
還是拿最開始的例子
var s1 = 'abc';var s2 = s1.indexOf('a')
變量s1是一個(gè)基本類型值,它不是對(duì)象,它不應(yīng)該有方法。但是js內(nèi)部為我們完成了一系列處理(即裝箱),使得它能夠調(diào)用方法,實(shí)現(xiàn)的機(jī)制如下:
(1)創(chuàng)建String類型的一個(gè)實(shí)例;
(2)在實(shí)例上調(diào)用指定的方法;
(3)銷毀這個(gè)實(shí)例;
下面來看看代碼實(shí)現(xiàn):
var s1 = new String('some text');var s2 = s1.substring(2);s1 = null;
這樣就完成裝箱,我們也就能在s1上調(diào)用方法了
拆箱:將引用類型對(duì)象轉(zhuǎn)換為對(duì)應(yīng)的值類型對(duì)象
拆箱:將引用類型對(duì)象轉(zhuǎn)換為對(duì)應(yīng)的值類型對(duì)象
它是通過引用類型的valueOf()或者toString()方法來實(shí)現(xiàn)的。如果是自定義的對(duì)象,你也可以自定義它的valueOf()/tostring()方法,實(shí)現(xiàn)對(duì)這個(gè)對(duì)象的拆箱。
var objNum = new Number(123); var objStr =new String('123'); console.log( typeof objNum ); //object console.log( typeof objStr ); //object console.log( typeof objNum.valueOf() ); //number console.log( typeof objStr.valueOf() ); //string console.log( typeof objNum.toString() ); // string console.log( typeof objStr.toString() ); // string
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. JAMon(Java Application Monitor)備忘記2. SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn)3. Java GZip 基于內(nèi)存實(shí)現(xiàn)壓縮和解壓的方法4. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法5. Docker容器如何更新打包并上傳到阿里云6. VMware中如何安裝Ubuntu7. Springboot 全局日期格式化處理的實(shí)現(xiàn)8. python 浮點(diǎn)數(shù)四舍五入需要注意的地方9. idea配置jdk的操作方法10. 完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題
