class Test:
TheFlag = True
StartNodeQuery = {1, 2, 3, 4, 5}
def parsa(self):
while self.TheFlag:
SNQ = self.StartNodeQuery
self.iterator(SNQ)
def iterator(self, CurrentNodeQuery):
#it prints {1, 2, 3, 4, 5}
print(CurrentNodeQuery)
if len(CurrentNodeQuery) < 100:
b = len(CurrentNodeQuery) * 2
c = len(CurrentNodeQuery) * 3
self.StartNodeQuery.update({b, c})
# it prints {1, 2, 3, 4, 5, 10, 15}
print(CurrentNodeQuery)
else:
self.TheFlag = False
assert 0
obj = Test()
obj.parsa()
如您所见,我故意以断言0结束程序。 主要问题是: 在函数完成之前,传递给它的参数已更改!
如您所见 StartNodeQuery = {1,2,3,4,5}和 SNQ = self.StartNodeQuery
所以为什么当我在函数完成前更改self.StartNodeQuery的大小时,CurrentNodeQuery是另一个变量,其值与self.StartNodeQuery(或SNQ)相同,即使我们没有这样做,不能将新的self.StartNodeQuery传递给CurrentNodeQuery吗?
希望您能理解我的问题,如果您有解决方案,请帮助一个人
答案 0 :(得分:0)
代码中的一些问题和建议
不要混合类和实例变量。您正在使用类变量TheFlag
和StartNodeQuery
作为实例变量,因此将它们设置为一个
使用构造函数实例化实例变量
也许使用exit()
来破坏功能
您需要通过copy.copy显式复制该集合以创建新实例。赋值SNQ = self.StartNodeQuery
只是对该变量进行了新引用
所以固定代码可能看起来像
from copy import copy
class Test:
def __init__(self):
# Made instance variables as class variables
self.TheFlag = True
self.StartNodeQuery = {1, 2, 3, 4, 5}
def parsa(self):
while self.TheFlag:
SNQ = self.StartNodeQuery.copy()
self.iterator(SNQ)
def iterator(self, CurrentNodeQuery):
#it prints {1, 2, 3, 4, 5}
print(CurrentNodeQuery)
if len(CurrentNodeQuery) < 100:
b = len(CurrentNodeQuery) * 2
c = len(CurrentNodeQuery) * 3
self.StartNodeQuery.update({b, c})
# it prints {1, 2, 3, 4, 5, 10, 15}
print(CurrentNodeQuery)
else:
self.TheFlag = False
#Use exit to break the function
exit()
obj = Test()
obj.parsa()
输出将是
{1, 2, 3, 4, 5}
{1, 2, 3, 4, 5}