JavaScript兩個(gè)變量交換值的實(shí)現(xiàn)方法
概要
本文主要描述,如何不使用中間值,將兩個(gè)變量的值進(jìn)行交換。
一、普通做法
var a = 1, b = 2, tmp; tmp = a; a = b; b = tmp;
普通的做法就是聲明多一個(gè)臨時(shí)變量tmp,進(jìn)行數(shù)據(jù)交換過(guò)程中的緩存。這樣的做法直觀,易懂。但是,會(huì)增加內(nèi)存的使用。
二、算術(shù)運(yùn)算
var a = 1, b = 2; a = a + b; // a = 3, b = 2 b = a - b; // a = 3, b = 1 a = a - b; // a = 2, b = 1
通過(guò)算術(shù)運(yùn)算過(guò)程中的技巧,可以巧妙地將兩個(gè)值進(jìn)行互換。但是,有個(gè)缺點(diǎn)就是變量數(shù)據(jù)溢出。因?yàn)镴avaScript能存儲(chǔ)數(shù)字的精度范圍是 -253 到 253。所以,加法運(yùn)算,會(huì)存在溢出的問(wèn)題。
三、異或運(yùn)算
var a = 1, // 二進(jìn)制:0001 b = 2; // 二進(jìn)制:0010 a = a ^ b; // 計(jì)算結(jié)果:a = 0011, b = 0010 b = a ^ b; // 計(jì)算結(jié)果:a = 0011, b = 0001 a = a ^ b; // 計(jì)算結(jié)果:a = 0010, b = 0001
本題巧用位運(yùn)算的技巧,利用 a ^ b ^ b == a 的特點(diǎn),進(jìn)行數(shù)值交換,避免了使用算術(shù)運(yùn)算帶來(lái)的弊端,不會(huì)發(fā)生溢出問(wèn)題。
四、ES6的解構(gòu)
let a = 1, b = 2; [a, b] = [b, a];
用解構(gòu)的語(yǔ)法特性,一次性解決,簡(jiǎn)單暴力,哈哈哈~
更重要的一點(diǎn):解構(gòu)語(yǔ)法還適用于其他類型的變量進(jìn)行互換。所以,用解構(gòu)可以很easy地進(jìn)行互換。
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
JavaScript利用fetch實(shí)現(xiàn)異步請(qǐng)求的方法實(shí)例
傳遞信息到服務(wù)器,從服務(wù)器獲取信息,是前端發(fā)展的重中之重,尤其是現(xiàn)在前后端分離的大前提下,前后端的數(shù)據(jù)交互是前端的必修科目了,下面這篇文章主要給大家介紹了關(guān)于JavaScript利用fetch實(shí)現(xiàn)異步請(qǐng)求的相關(guān)資料,需要的朋友可以參考借鑒。2017-07-07
knockoutjs動(dòng)態(tài)加載外部的file作為component中的template數(shù)據(jù)源的實(shí)現(xiàn)方法
Knockoutjs 的Components 是一種自定義的組件,它以一種強(qiáng)大、簡(jiǎn)介的方式將你自己的ui代碼組織成一種單獨(dú)的、可重用的模塊。接下來(lái)通過(guò)本文給大家介紹knockoutjs動(dòng)態(tài)加載外部的file作為component中的template數(shù)據(jù)源的實(shí)現(xiàn)方法,一起看看吧2016-09-09
layui數(shù)據(jù)表格重載實(shí)現(xiàn)往后臺(tái)傳參
今天小編就為大家分享一篇layui數(shù)據(jù)表格重載實(shí)現(xiàn)往后臺(tái)傳參,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
淺析JS動(dòng)態(tài)創(chuàng)建元素【兩種方法】
下面小編就為大家?guī)?lái)一篇淺析JS動(dòng)態(tài)創(chuàng)建元素【兩種方法】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家。一起跟隨小編過(guò)來(lái)看看吧2016-04-04
解決layer彈出層的內(nèi)容頁(yè)點(diǎn)擊按鈕跳轉(zhuǎn)到新的頁(yè)面問(wèn)題
今天小編就為大家分享一篇解決layer彈出層的內(nèi)容頁(yè)點(diǎn)擊按鈕跳轉(zhuǎn)到新的頁(yè)面問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
如何在現(xiàn)代JavaScript中編寫(xiě)異步任務(wù)
這篇文章主要給大家介紹了關(guān)于如何在現(xiàn)代JavaScript中編寫(xiě)異步任務(wù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
javascript實(shí)現(xiàn)點(diǎn)擊圖片切換
這篇文章主要介紹了javascript實(shí)現(xiàn)點(diǎn)擊圖片切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04

