我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
我有两个变量:
var a = 1,
b = 2;
我的问题是如何交换它们?只有这个变量,没有任何对象。
当前回答
ES6 (Firefox和Chrome已经支持它 数组匹配)):
设a = 5, b = 6; [a, b] = [b, a]; console.log(“${一}$ {b}”);
其他回答
你可以这样做:
var a = 1,
b = 2,
tmp;
tmp = a;
a = b;
b = tmp;
对于可读性和可维护性,这是无可比拟的(至少在JavaScript中)。任何维护代码的人(包括六个月后的您)都将确切地知道发生了什么。
由于这些都是整数,您还可以使用任意数量的聪明技巧进行交换,而不需要使用第三个变量。例如,你可以使用按位的xor操作符:
设a = 1, b = 2; A = A ^ b; B = a ^ B; A = A ^ b; Console.log ('a现在是:',a); Console.log ('b现在是:',b);
这叫做异或交换算法。维基百科的这篇文章描述了它的运作理论。
“有能力的程序员清楚地意识到自己脑袋的大小是有限的。因此,他以完全谦卑的态度对待他的任务,并避免像瘟疫一样的聪明伎俩。”——埃德斯格·迪克斯特拉
您可以使用临时交换变量或XOR。
a = a ^ b
b = a ^ b
a = a ^ b
这只是一个基本的逻辑概念,适用于支持异或操作的每种语言。
编辑:见注释。忘了说,这只适用于整数。假设问题线程中的整数变量
我们怎么会错过这些经典的俏皮话呢
var a = 1, b = 2
a = ({a:b, _:(b=a)}).a;
And
var a = 1, b = 2
a = (_=b,b=a,_);
最后一个暴露了全局变量“_”,但这并不重要,因为典型的javascript惯例是使用它作为“不在乎”变量。
从ES6开始,你还可以更优雅地交换变量:
var a = 1,
b = 2;
[a, b] = [b, a];
console.log('a:', a, 'b:', b); // a: 2 b: 1
不要使用下面的代码。这不是交换两个变量值的推荐方法(简单地使用临时变量)。它只是展示了一个JavaScript技巧。
这个解决方案不使用临时变量,不使用数组,只添加一次,而且速度很快。 事实上,在一些平台上,它有时比临时变量更快。 它适用于所有数字,从不溢出,并处理边界情况,如无穷大和NaN。
a = b + (b=a, 0)
它分两步工作:
(b=a, 0)将b设置为a的旧值并产生0 A = b + 0将A设置为b的旧值