C++ 里面没有规定这个词。一些讲面向对象的书里时有遇到。
通常称那些将其他类的对象作为一个类的数据成员的方法为复合类,这主要是相对于用继承的方法来联系两个类而言。使用复合类的方法也常称为聚集。
复合(composite)和聚集(Aggregation)
如果类的数据成员和类有相同的生命周期,是复合关系,即类
实例不存在了,类成员也不会存在,如:
class A{
class B b; //A不存了,b也不存在了
}
如果不一定满足这个条件则才是聚集关系,如:
class A{
class B* b; //存在这样的情况:b指向的内存不一定实在A内部分配,可能是外面传进
//来的,当A消失了,b指向的内存可能还在
}
UML的说法是:关联(associaction)>聚集(Aggregation)>复合(composite),做系统详细
设计的时候经常用到。
通常称那些将其他类的对象作为一个类的数据成员的方法为复合类,这主要是相对于用继承的方法来联系两个类而言。使用复合类的方法也常称为聚集。
复合(composite)和聚集(Aggregation)
如果类的数据成员和类有相同的生命周期,是复合关系,即类
实例不存在了,类成员也不会存在,如:
class A{
class B b; //A不存了,b也不存在了
}
如果不一定满足这个条件则才是聚集关系,如:
class A{
class B* b; //存在这样的情况:b指向的内存不一定实在A内部分配,可能是外面传进
//来的,当A消失了,b指向的内存可能还在
}
UML的说法是:关联(associaction)>聚集(Aggregation)>复合(composite),做系统详细
设计的时候经常用到。