Python小记:12.从a,b=b,a+b理解数值互换(Python变量的内存机制)

  • Post author:
  • Post category:python


之前看到一个计算斐波那契数列前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赋值运算是先计算等号右边的,右边全计算完(第一次循环计算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 和==的区别
  • c和d同理,无非是创建了一个list列表,又指向了数值

如果想了解更细节的内存机制,可以参考

该博主



版权声明:本文为weixin_44671418原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。