成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

七種交換變量值的方法,看看你知道幾種

開發 前端
你知道交換兩個變量的值有多少種方法?我很慚愧,因為我只知道兩種方法。事實上,至少有 7 種方法可以做到這一點,是不是有點太不可思議了?什么,你不相信我?我不會騙你的,跟我來!

1.使用臨時變量交換兩個值

這是每個前端開發工程師都應該知道的一種方法,我們可能在學生時代就學過這種技術。

let a = 1
let b = 2
// Use a temporary variable to store the value of b first
let temp = b
b = a
a = temp
temp = null
console.log('a', a, 'b', b)

這種方法的優點是非常簡單易懂。缺點是需要多聲明一個變量,這意味著程序需要占用更多的計算機內存。

2.使用ES6中的解構賦值

我相信大家對 ES6 已經很熟悉了,它有一個很棒的特性叫做解構。

使用解構功能,我們可以輕松交換兩個變量的值。

let a = 1
let b = 2
;[ a, b ] = [ b, a ]
console.log('a', a, 'b', b)

我個人真的很喜歡這種方式了,我們不需要使用任何額外的代碼來完成這項工作。

3.使用異或 (^)

如果你對它非常感興趣,可以點擊這里(鏈接)進行深入研究。

不過別著急,相信看完這張表的內容你就知道是怎么回事了:

即使我們只需要知道這兩個知識點就足夠了:

  • (“0”^任何值)等于這個值。
  • 100 ^ 100 等于 0
0 ^ 100 // 100
100 ^ 100 // 0

我想,你一定已經猜到該怎么做了!

let a = 1
let b = 2
a = a ^ b
// 1. => a ^ b ^ b
// 2. => a ^ 0
// 3. => b = a = 1
b = a ^ b
// 1. a ^ b => a ^ b ^ a
// 2. a ^ b ^ a => 0 ^ b
// 3. a = b = > 2
a = a ^ b
console.log('a', a, 'b', b)

4.使用加法交換兩個變量的值

什么?你在搞笑嗎?沒有,你可以使用加法交換兩個變量的值。

let a = 1
let b = 2
a = a + b // The value of a is a(1) + b(2) = 3
b = a - b // The value of b is a(3) - b(2) = 1
a = a - b // The value of a is a(3) - b(1) = 2
console.log('a', a, 'b', b)

5.使用減法交換兩個變量的值

既然我們可以使用加法交換兩個變量的值,為什么不試試減法呢?

let a = 1
let b = 2
a = a - b // The value of a is a(1) - b(2) = -1
b = b + a // The value of b is b(2) + a(-1) = 1
a = b - a // The value of a is b(1) - a(-1) = 2
console.log('a', a, 'b', b)

那么使用加法和減法到底有什么區別呢?朋友們,你們一定知道JavaScript中有一個最大的安全數,那么,如果我們使用加法,會不會超過這個數呢?是的,這個問題可以通過使用減法來避免。

6.使用對象交換兩個變量的值

我們可以將對象用作交換兩個變量的橋梁,并讓它鏈接所有這些。

let a = 1
let b = 2
a = {
a: a,
b: b
}
b = a.a
a = a.b
console.log('a', a, 'b', b)

你能用數組來完成這個嗎?

let a = 1
let b = 2
a = [ a, b ]
b = a[ 0 ]
a = a[ 1 ]
console.log('a', a, 'b', b)

7.使用“,”逗號運算符

1).數組和“,”的組合:

let a = 1
let b = 2
a = [b, (b = a)][0]
// The code roughly goes through the following steps
// 1. b = a => b = 1
// 2. a = [ 2, 1 ]
// 2. a = [ 2, 1 ][0] => 2
console.log('a', a, 'b', b)

2).賓語與“,”的組合:

let a = 1
let b = 2
a = b + ((b = a), 0)
// The code roughly goes through the following steps
// 1. a = 2 + ((b = 1), 0) => b = 1
// 2. a = 2 + 0 => a = 2
console.log('a', a, 'b', b)


責任編輯:龐桂玉 來源: 大前端私房菜
相關推薦

2018-01-30 17:54:37

數據庫MySQLSQL Server

2023-03-28 11:40:07

邊緣計算云計算

2022-05-18 09:01:31

JavaScriptEvalErrorURIError

2025-01-15 10:46:23

開發JavaScript集合

2010-09-16 17:47:49

2016-09-28 20:05:22

2014-05-13 09:56:24

數據挖掘

2011-12-16 14:45:36

JavaJSP

2011-05-30 13:37:46

JSP

2025-05-13 08:20:58

2022-10-27 08:09:33

2023-04-18 15:57:30

2024-07-29 08:00:00

2024-10-21 13:05:40

2017-02-05 10:51:13

2022-09-30 10:48:12

AR制造業

2010-01-21 10:41:58

2025-01-21 08:00:00

限流微服務算法

2022-05-10 08:08:01

find命令Linux

2020-01-14 08:00:00

.NET緩存編程語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区视频在线播放 | 97精品国产一区二区三区 | 国产精品无码专区在线观看 | 欧美在线a | 91玖玖| 91免费看片神器 | 日韩精品在线免费观看 | 亚洲激情在线视频 | 日韩精品区 | 久久久久一区二区三区 | 欧美6一10sex性hd | 一区二区三区国产 | 伊人伊人网 | 天天躁日日躁狠狠躁白人 | 国产乱码精品一区二三赶尸艳谈 | 国产日韩精品视频 | 欧美999| 九九综合| 国产精品久久久久久婷婷天堂 | 久久久成人免费视频 | 国产99精品 | www.国产精品| 欧美视频日韩 | 久久久久久国产 | 日本久久网站 | 阿v视频在线观看 | 成人在线视频观看 | 一区二区中文字幕 | 久久久久亚洲精品 | 亚洲精品电影网在线观看 | 欧美在线视频a | 激情五月综合网 | 国产视频久久久 | a级毛片毛片免费观看久潮喷 | 一级毛片色一级 | 亚洲一区二区视频 | 亚洲成人久久久 | 国产日韩欧美一区 | 99久久婷婷国产亚洲终合精品 | 97人人澡人人爽91综合色 | 久久久一二三 |