如何解决当我传递一个列表而不是一个浮点数或整数时,为什么我的类实例在每次迭代后保存最终值?
我想创建一个实例方法,其中包含一个修改实例内部变量之一的函数,然后多次迭代此操作。这是我的代码示例:
class test:
def __init__(self,counter):
self.x = counter
def func(self):
self.x = self.x + 1
def routine(dat):
t1 = test(dat)
print('Initial Count: ',t1.x)
for i in range(3):
t1.func()
print('Final Count: ',t1.x)
def main(dat):
for i in range(3):
print('Iter; ',i,'Init Value: ',dat)
routine(dat)
print('Iter; ','Final Value: ',dat)
D = 0
main(D)
如果我将整数 D 传递给方法 t1 并调用函数 func() 3 次,则整数增加 3。如果我运行了 3 次,如函数 main() 所示,并且不在迭代之间更改变量 dat,则 dat 在迭代之间不会更改。此外,变量 self.x 每次都会重置,如下所示:
这按预期工作。
但是,如果我将 D 设置为包含整数 D=[0]
的列表,并相应地修改函数 func():
def func(self):
self.x[0] = self.x[0] + 1
这样我就增加了列表中的值,然后 self.x 不会在迭代之间重置,而且函数 main() 中的变量 dat 现在表现得好像它是一个全局变量。如果你运行这个修改的代码,你会得到这个:
为什么我的代码会这样?我需要做什么才能使修改后的版本表现得与以前的版本相似?我想传递一个数组,操作数组中的值,输出结果,然后使用相同的初始条件重新执行。
更新
感谢您的回复。这种行为的原因是列表是可变的。我需要将 D 设置为一个元组并在方法内重新创建列表。修改如下:
D = (0,)
def __init__(self,counter):
self.x = [i for i in counter]
解决方法
发生这种情况是因为 variable referencing
机制。
让我们一步一步来。
我建议阅读我的articles
case-1
D = 0
所以 D
是一个整数。整数是不可变的。
D = 0
A = D
A += 1
print(A) # it will print 1
print(D) # it will print 0
case-1
D = [0]
D 是 list
。列表是可变的。
D = [0]
A = D
A[0] += 1
print(A) # it will print [1]
print(B) # it will print [1]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。