python类初始化参数赋值,实例直接调用append函数后,导致所有实例中变量改动

问题描述

刚宿舍的问了个问题,简单的说就是编程遇到了如下的这种情况:

class Node(object):
    def __init__(self ,childrenList=[], name = '.' ):
        self.name = name
        self.childrenList = childrenList
a = Node(name = 'wj')
b = Node()
a.childrenList.append(1)
print(a.childrenList)
print(b.childrenList)

输出如下:

[1]
[1]

原因

很奇怪,实例a的赋值,导致b中变量childrenList也变了。

直觉上来说,应该是函数参数赋值是值传递还是引用传递的问题,当然本质上还是传的值,只是赋值对象是可变还是不可变的问题。

所以,来测试一下:

class Node(object):
    def __init__(self ,childrenList=[], name = '.' ):
        self.name = name
        self.childrenList = childrenList
        print("childrenList",id(self.childrenList))
        print("name",id(self.name))
a = Node(name = 'wj')
b = Node()
a.childrenList.append(1)
print(a.childrenList)
print(b.childrenList)

结果

childrenList 2754369477512
name 2754369477232
childrenList 2754369477512
name 2754335175152

可以看到,name字符串在两个实例中的内存位置不同,但childrenList却是同一个,那就会出现1中的结果。

修改

最简单的可以直接使用self.childrenList=[]赋值,这样的话就是用不到参数中的值。

更好一点的方法可以使用python的深拷贝。

import copy
class Node(object):
    def __init__(self ,childrenList=[], name = '.' ):
        self.name = name
        self.childrenList = copy.deepcopy(childrenList)
a = Node(name = 'wj')
b = Node()
a.childrenList.append(1)
print(a.childrenList)
print(b.childrenList)

这样,生成的实例中childrenList就会指向不同的单位。

你可能感兴趣的:(python)