之前看到一个计算斐波那契数列前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
这样一看就想起来了,Python有这样一个简易的数值交换方式。
-
例如交换a和b的值:
-
Python:
-
a,b=b,a
-
-
在C中需要引入临时存储变量temp:
-
int temp;a=temp;a=b;b=temp;
-
-
Python:
这是为什么呢?
因为:Python赋值运算是先计算等号右边的,右边全计算完(第一次循环计算a=0,a+b=1)再向左侧赋值(将a+b、a的值赋给左侧的b、a),而右侧的计算并不影响左侧的值。这与Python独特的变量机制有关:
-
Python的变量并不直接存储值,而只是引用一个内存地址,交换变量时,只是交换了引用的地址。
- 更通俗讲,就是Python中的变量,比如a,只是一块地址叫a,内部没存具体的数值。我们令a=11时,是单独开辟了一个空间存储11这个数值,然后用a来指向这个空间。
- 当我们继续a=12时,是又单独开辟了一个空间存储12这个数值,然后a指向11的箭头变成了指向12。
一个例子加强理解:
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]的地址。
下面画图分步解释一下:
- a=12:
-
b=a
-
生成b
-
指向a(此时的a和b不仅是value相同,id也相同)
-
这里有个相关知识点,
is 和==的区别
-
生成b
- c和d同理,无非是创建了一个list列表,又指向了数值
如果想了解更细节的内存机制,可以参考
该博主
版权声明:本文为weixin_44671418原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。