python 变量引用

最近在看<<流畅的python>>关于变量引用部分时,有一些自己的看法,就再次记录一下.

问题:

# From flunet python example 8-8
class Bus:
    def __init__(self, passengers=[]):
        self.passengers = passengers

    def pick(self, name):
        self.passengers,append(name)
    
    def remove(self, name):
        self.passengers.remove(name)

>> bus1 = Bus()    # 实例化
>> bus2 = Bus()    # 实例化
>> bus1.append('Bob')
>>bus2.passengers    # bus2的passengers也有值     
 ['Bob']  

为什么bus1中passengers发生改变会导致bus2中passengers发生改变?

这说明两个Bus的实例共用了一个self.passengers,明明是两个实例?

在往上看,self.passengers引用的是passengers的值,也就是__init__中的形参(变量).这个参数在两个实例中是共用的,实例化的过程中,都会用到passengers这个list.

再仔细想一想,每一次实例化过程不都会新建一个passengers吗?这就是问题的所在.答案是passengers这个形参并不是在实例化过程中建立的,而是在方法定义的时就产生了.也就是因为在这个过程早于实例化过程,不同的实例才能共享passengers变量.

再定义一个函数:

def foo(x=[]):
    print id(x)

>> f1 = foo()
139916453629536
>> f2 = foo()
139916453629536

两次id是一样的,也说明参数x的内存空间是在函数定义时创建的

看看foo函数的默认参数变量以及id

>> foo.func_defaults
([],)
>> id(foo.func_defaults[0])
139916453629536

可以看到id的结果都是一样的,同样也验证了参数变量的内存空间是在调用之前(定义时)创建的.

回头看看,除了参数变量的引用之外,还有几点看法:

(1)方法和函数的参数引用方式是一致的,都是在定义时创建内存空间

(2)函数也是function类的实例

猜你喜欢

转载自www.cnblogs.com/chimpan/p/9426724.html
今日推荐