我试图让用户制作一个名为NoteSet的对象,每个NoteSet都将被放入一个名为db的全局列表中。这是我的尝试:
import sys
import datetime
db = list()
class NoteSet:
nextseqNum = 0
def __init__(self,name,description,hidden):
global db
self.seqNum = Note.nextseqNum
self.name = name
self.description = description
self.dateCreated = datetime.date.today()
self.hidden = hidden
self.notes = list()
db[self.seqNum] = self
print(self)
print(len(db))
Note.nextseqNum += 1
例如,当我尝试创建对象时:
^{pr2}$它给了我错误
Traceback (most recent call last): File "", line 1, in NoteSet('example','ex',True) File "C:\Users\Brandon\Desktop\step5.py", line 22, in init db[self.seqNum] = self IndexError: list assignment index out of range
这是生成全局对象列表的正确方法吗?在
出现此错误是因为
db
中没有元素(python列表被初始化为长度为0),因此当您尝试替换位于self.seqNum
的元素时,您正在访问一个无效的索引。这与它的全球性无关。在如果我们假设只能以线程安全的方式访问这个全局列表,那么您应该能够:
相反。然而,正如注释中提到的,如果这个类是与db列表接口的“看门人”,那么在这个用例中,使
db
成为一个类变量更有意义。在更新
为了在评论中回答OP的问题
如前所述,
seqNum
将永远线性递增,与每个新的NoteSet
实例一起。如果我们假设Note.nextseqNum
的线程安全访问,那么通过db[self.seqNum]
所做的事情已经通过db.append(self)
隐式地完成了,因为len(db) == Note.nextseqNum
总是这样。现在,我们将忽略如果您可以从db
中删除元素会发生什么,因为现在您的系统根本不考虑这个问题,无论如何都会完全崩溃。在但是,如果将来
^{pr2}$seqNum
不是每次生成一个新实例时都单调地增加,那么您可以简单地使db
变成dict
,而不是list
:然后将新实例完全插入到它中
db
现在显式表示seqNum
到NoteSet
的映射,而不是基于数组索引的隐式关系。在实际上,我还是建议这样做,因为它还可以解决从}的所有映射完全无效。但是如果}值仍然映射到
db
中“免费”删除项的问题。也就是说,对于删除的实例之后的任何实例,执行del db[instance.seqNum]
操作将使seqNum
到{db
是一个dict
,那么这个操作会按照您的预期操作,并且所有的{db
中的正确实例。在因此,为了把它们结合起来,我建议您将类更改为如下所示:
正如@aruisdante所说,你需要在列表中附加
试试这个:
祝你好运!在
相关问题 更多 >
编程相关推荐