4種在JavaScript中交換變量的方法

英文 |?https://dmitripavlutin.com/
作者 | dmitripavlutin
譯文 | 做工程師不做碼農(nóng)
1、解構(gòu)賦值
let a;let b;[] = [1, 2, 3];a; // => 1b; // => 2
[a,b] = [1,2,3]?是對?[1,2,3]?數(shù)組進(jìn)行解構(gòu)的解構(gòu)賦值。[1,2,3]?的第一項1 分配了一個變量 a,第二項 2 對應(yīng)地分配了 b。
知道如何解構(gòu)數(shù)組,可以很容易地使用它交換變量。讓我們使用解構(gòu)分配交換變量 a和 b:
let a = 1;let b = 2;[] = [b, a];a; // => 2b; // => 1
2、?臨時變量
let a = 1;let b = 2;let temp;temp = a;a = b;b = temp;a; // => 2b; // => 1
3、?加減法
您可以交換變量而無需使用額外的內(nèi)存(例如臨時數(shù)組或變量)。
以下示例使用加法?+?和差分-?算術(shù)運算符交換變量 a 和 b:
let a = 1;let b = 2;a = a + b;b = a - b;a = a - b;a; // => 2b; // => 1
a = a + b賦予a值1 + 2。 b = a - b為b賦值1 + 2 - 2 = 1(b現(xiàn)在為1)。 a = a - b為a分配值1 + 2 - 1 = 2(a現(xiàn)在為2)。
首先,您只能交換整數(shù)。 其次,在第一步a = a + b進(jìn)行加法時要注意數(shù)字溢出(總和必須小于Number.MAX_SAFE_INTEGER)。
4、?按位XOR運算符
| a | b | a ^ b |
|---|---|---|
| 0 | 0 | 0 |
| 1 | 1 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
在JavaScript中,按位 XOR 運算符 n1 ^ n2 對n1和n2數(shù)字的每一位執(zhí)行 XOR 操作。
舉例來說,這是 5 ^ 7 評估(evaluates)為2的方式:
1 0 1 (5 的二進(jìn)制)1 1 1 (7 的二進(jìn)制)-----0 1 0 (5 ^ 7 = 2 的二進(jìn)制)
按位 XOR 具有 2 個有趣的屬性:
n ^ n = 0:對相同數(shù)字執(zhí)行的按位 XOR 為0.
n ^ 0 = n:對一個數(shù)字執(zhí)行按位異或,零是相同數(shù)字.
這些 XOR 屬性可用于交換變量。讓我們看看如何交換a和b變量:
let a = 1;let b = 2;a = a ^ b;b = a ^ b;a = a ^ b;a; // => 2b; // => 1
交換過程:
a = a ^ b
b = a ^ b?;? a被a ^ b取代。因此b =(a ^ b)^ b = a ^(b ^ b)= a ^ 0 = a。請記住,現(xiàn)在b不是a。
a = a ^ b?;? a的a替換為a ^ b,基于2 b的a替換為a。因此a =(a ^ b)^ a = b ^(a ^ a)= b ^ 0 = b。變量a變?yōu)閎。
如果您覺得解釋很復(fù)雜,請隨時跳過。由3個賦值組成的按位XOR(n ^ n = 0和n ^ 0 = n)的性質(zhì)使您可以交換a和b的值。
使用按位XOR運算符交換變量有局限性:您只能交換整數(shù)。
5、結(jié)論
JavaScript提供了很多交換變量的好方法,無論有沒有額外的內(nèi)存。
我建議使用的第一種方法通過應(yīng)用解構(gòu)賦值[a,b] = [b,a]交換變量。這是一種簡短而富有表現(xiàn)力的方法。
第二種方法使用臨時變量。這是代替(applying)解構(gòu)賦值方法的不錯選擇。
第三種方法,使用加減法,不使用其他變量或內(nèi)存。但是,該方法僅限于交換整數(shù)。
同樣,使用按位XOR的第四種方法不使用額外的內(nèi)存。但是同樣,您只能交換整數(shù)。
你覺得交換變量的首選方式是什么?

