之前看到一个计算斐波那契数列前n项的代码:
def fab(max):
n, a, b = 0, 0, 1
L = []
while n < max:
L.append(b)
a, b = b, a + b
n = n + 1
return L
for n in fab(5):
print n
里面有一段a, b = b, a + b
给我看蒙了
a,
中间让b=b
(自己等于自己?)是咋回事?原来是自己断句(优先级)搞错了,应该是看做:
a,b
断=
断 b,a+b
例如交换a和b的值:
a,b=b,a
int temp;a=temp;a=b;b=temp;
因为:Python赋值运算是先计算等号右边的,右边全计算完(第一次循环计算a=0,a+b=1)再向左侧赋值(将a+b、a的值赋给左侧的b、a),而右侧的计算并不影响左侧的值。这与Python独特的变量机制有关:
a=12
b=a
c=[1,2,3,4]
d=c
print (id(a),id(b))
print (id(c),id(d))
结果:
140706711905008 140706711905008
3194113089416 3194113089416
可以看到,a和b的地址相同,都是数值12的地址;c和d的地址相同,都是[1,2,3,4]的地址。
下面画图分步解释一下:
如果想了解更细节的内存机制,可以参考该博主