如果我正确理解,聚合与组合是关于对象对其成员的职责(例如,如果删除实例,是否还要删除其成员?)。
主要地,它将在很大程度上取决于实施。例如,要创建一个接收类B(聚合)实例的类A,可以编写以下代码:
class B(object): passclass A(object): def __init__(self, b): self.b = bb = B()a = A(b)
但请注意,Python内置没有任何东西可以阻止您传递其他信息,例如:
a = A("string") # still valid
如果要在A(组成)的构造函数中创建B的实例,则可以编写以下内容:
class A(object): def __init__(self): self.b = B()
或者,您可以将类注入构造函数,然后创建一个实例,如下所示:
class A(object): def __init__(self, B): self.b = B()
顺便说一句,至少在第一个示例(可能还有第二个示例)中,您将B设置为B的类定义,而不是它的实例:
class A(object): def __init__(self, B): self.B = B>>> a = A()>>> a.B # class definition<class __main__.B at 0x028586C0>>>> a.B() # which you can make instances of<__main__.B instance at 0x02860990>
因此,最后得到一个A实例,该实例指向B的类定义,我很确定这不是您的追求。虽然,用其他语言通常很难做到这一点,所以我理解这是否是混淆点之一。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)