Python中对象及引用的理解

def func(ls=[]):
    ls.append(1)
    return ls

a = func()
b = func()

print(a, b)

考虑这段代码的输出,要理解Python中对象及引用的概念。

首先,在整个代码中,a = func()是func函数的第一次执行。在这次调用执行中,func函数的ls参数使用了默认值[],也就是一个空列表对象

调用结束后,这个列表对象的值变成了[1],被return给了调用者。这时,这个对象是包含一个元素的列表,有两个变量指向它,a变量和ls变量,也可以说a和ls是这个对象的引用。这里要注意,这时由于有外部变量a指向它(引用它),所以调用结束后它的存储空间并没有被销毁,它的值[1]被保留着。

所以在b = func()这次调用中,ls这个参数所指向的存储空间存在且已经有值[1],所以这次调用不需要使用默认值,而使用它已经有的值进行运算,运算结束后返回给了b。

最后,变量a,b,ls都指向这个对象,值都是[1,1]。

 

总结,python中,一切存储空间都是一个对象,变量名都是对这个对象的引用。当所有对它的引用(变量),生命周期都结束了,系统就销毁了这个对象,回收存储空间。

上面是2019-09-20的理解。


下面是2019-11-5的更新 

最近又研究了一下这个问题,发现下面的代码同样会在最后输出[1, 1]。

def func(ls=[]):
    ls.append(1)
    print(ls)
 
func()
func()

在这段代码中就没有变量a,b影响ls的生命周期了,但ls的值仍然在内存中,所以上面的理解就不准确了。

后来查了一下资料,发现问题不在引用这个概念上,而是在python中,对于函数的默认参数,会有单独的位置存储它,它会随着函数本身的生命周期而存在。所以像上面的代码,ls变量是func函数的一个属性(可以用func.__defaults__查看),它是和func函数绑定在一起的,像上面的每次调用,都是在给func.__defaults__这个变量在append值,结果就是最后输出累加的[1,1]列表。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值