复合(composite)和聚集(Aggregation)

C++ 里面没有规定这个词。一些讲面向对象的书里时有遇到。

通常称那些将其他类的对象作为一个类的数据成员的方法为复合类,这主要是相对于用继承的方法来联系两个类而言。使用复合类的方法也常称为聚集。

复合(composite)和聚集(Aggregation)

如果类的数据成员和类有相同的生命周期,是复合关系,即类
实例不存在了,类成员也不会存在,如:
class A{
 class B b;  //A不存了,b也不存在了
}
如果不一定满足这个条件则才是聚集关系,如:
class A{
 class B* b; //存在这样的情况:b指向的内存不一定实在A内部分配,可能是外面传进
            //来的,当A消失了,b指向的内存可能还在
}
UML的说法是:关联(associaction)>聚集(Aggregation)>复合(composite),做系统详细
设计的时候经常用到。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值