我写了一个代码:
class NewsStory(object):
def __init__(self, guid, title, subject, summary, link):
NewsStory.guid = guid
NewsStory.title = title
NewsStory.subject = subject
NewsStory.summary = summary
NewsStory.link = link
def getGuid(self):
return self.guid
def getTitle(self):
return self.title
def getSubject(self):
return self.subject
def getSummary(self):
return self.summary
def getLink(self):
return self.link
当我添加一个实例为:
test = NewsStory('foo', 'myTitle', 'mySubject', 'some long summary', 'www.example.com')
print test.getGuid()
给我foo
,这是正确的。但是,如果我连续创建两个实例:
test = NewsStory('foo', 'myTitle', 'mySubject', 'some long summary', 'www.example.com')
test1 = NewsStory('foo1', 'myTitle1', 'mySubject1', 'some long summary1', 'www.example1.com')
双方print test.getGuid()
并print test1.getGuid()
给了我foo1
,但没有foo
。为什么会发生?是否有一种方法可以修改类定义或类中的函数,以避免新创建的实例覆盖旧实例?
谢谢。
您需要在__init__
函数实例变量而不是类变量中创建这些变量。
实例变量如下所示:
self.guid = guid
类变量如下所示:
NewsStory.guid = guid
类变量对于该类的所有成员都是相同的,但是实例变量对于该类实例是唯一的。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句