当前位置: 首页 > news >正文

【Java三种聚合方式之生命周期】

在 Java 中,**聚合(Aggregation)**关系体现的是一种较弱的包含关系。被聚合的对象的生命周期独立于容器对象,即容器对象并不管理被聚合对象的创建和销毁。下面详细分析 聚合的三种方式EngineCar 的生命周期区别。

1. 通过构造函数传入外部创建的对象

class Engine {
    public void start() {
        System.out.println("发动机启动");
    }
}

class Car {
    private Engine engine; // 引用外部创建的 Engine 对象

    // 通过构造函数接收外部传入的 Engine 对象
    public Car(Engine engine) {
        this.engine = engine; // 聚合:Car 使用外部创建的 Engine
    }

    public void drive() {
        engine.start();
        System.out.println("汽车正在行驶");
    }

    public static void main(String[] args) {
        Engine engine = new Engine(); // 外部创建 Engine 对象
        Car car = new Car(engine); // 将 Engine 对象传入 Car
        car.drive();
    }
}
生命周期分析:
  • Car 的生命周期
    • 当通过 new Car(engine) 创建 Car 对象时,Car 的生命周期开始。Car 持有一个 Engine 引用,但并不负责 Engine 的创建。
    • Car 对象在 new Car() 调用时创建,但不会控制 Engine 的销毁,它只持有 Engine 的引用。
  • Engine 的生命周期
    • Engine 对象是在外部创建的(在 main 方法中),它的生命周期独立于 Car 对象。Engine 的创建和销毁由外部代码控制,Car 只是通过构造函数将 Engine 引用传入。
    • Engine 的销毁时机取决于外部代码的控制,而非 Car 类。

总结:

  • Car 仅持有 Engine 的引用,但它不管理 Engine 的生命周期。Engine 的生命周期由外部管理,Car 仅在需要时使用。

2. 通过 Setter 方法设置对象

class Engine {
    public void start() {
        System.out.println("发动机启动");
    }
}

class Car {
    private Engine engine; // 引用外部创建的 Engine 对象

    // 通过 setter 方法将外部创建的 Engine 对象注入
    public void setEngine(Engine engine) {
        this.engine = engine; // 聚合:Car 使用外部创建的 Engine
    }

    public void drive() {
        engine.start();
        System.out.println("汽车正在行驶");
    }

    public static void main(String[] args) {
        Engine engine = new Engine(); // 外部创建 Engine 对象
        Car car = new Car();
        car.setEngine(engine); // 使用 setter 注入 Engine
        car.drive();
    }
}
生命周期分析:
  • Car 的生命周期
    • Car 对象的生命周期由 new Car() 控制,Car 会持有一个 Engine 引用,但它的生命周期不管理 Engine 对象。
    • main 方法中,Engine 是在外部创建的,并通过 setEngine() 方法传递给 CarCar 只负责使用 Engine 对象,并不会销毁 Engine
  • Engine 的生命周期
    • Engine 对象的生命周期完全独立,由外部代码控制。在 Car 创建之前,Engine 已经被创建;在 Car 销毁时,Engine 并不会随之销毁。
    • 只有外部代码显式销毁 EngineEngine 的生命周期才会结束。

总结:

  • 在这种方式下,Car 仅依赖于外部创建并传递给它的 Engine 对象。Car 使用 Engine,但并不管理其生命周期。Engine 的销毁由外部控制。

3. 使用集合类型的聚合

import java.util.List;
import java.util.ArrayList;

class Engine {
    public void start() {
        System.out.println("发动机启动");
    }
}

class Car {
    private List<Engine> engines = new ArrayList<>(); // 聚合:Car 可以包含多个 Engine 对象

    // 通过方法添加外部创建的 Engine 对象
    public void addEngine(Engine engine) {
        engines.add(engine); // 聚合:Car 依赖外部创建的 Engine
    }

    public void drive() {
        for (Engine engine : engines) {
            engine.start();
        }
        System.out.println("汽车正在行驶");
    }

    public static void main(String[] args) {
        Engine engine1 = new Engine(); // 外部创建 Engine 对象
        Engine engine2 = new Engine();
        
        Car car = new Car();
        car.addEngine(engine1); // 将 Engine 对象添加到 Car 中
        car.addEngine(engine2);
        car.drive();
    }
}
生命周期分析:
  • Car 的生命周期
    • Car 的生命周期由 new Car() 控制,Car 内部包含一个 List<Engine> 用来保存 Engine 对象的引用。Car 的生命周期会在 new Car() 时开始,但它并不负责 Engine 的创建或销毁。
    • Car 会在 addEngine() 方法中将外部创建的 Engine 对象添加到 engines 集合中,但是它不会管理这些对象的生命周期。
  • Engine 的生命周期
    • Engine 对象的生命周期完全独立于 CarEngine 是在外部创建的,可以被多个 Car 对象共享。
    • Engine 对象的销毁与 Car 无关,Car 只是通过 addEngine() 方法持有 Engine 对象的引用,并不会影响它们的生命周期。

总结:

  • 在这种方式下,Car 仅持有对 Engine 对象的引用,并通过集合(如 List)来保存多个 Engine 对象。Engine 的生命周期由外部控制,而 Car 不负责管理这些 Engine 对象的销毁。

总结对比:

方式Car 的生命周期Engine 的生命周期
通过构造函数传入外部创建的对象Car 对象的生命周期由 new Car() 控制,Car 持有 Engine 引用,但不负责 Engine 的销毁Engine 的生命周期独立于 Car,由外部控制,Car 不管理 Engine 的创建和销毁。
通过 Setter 方法设置对象Car 对象的生命周期由 new Car() 控制,Car 依赖外部传入的 EngineEngine 的生命周期由外部控制,不依赖于 Car,可以在多个容器中共享。
使用集合类型的聚合Car 持有 Engine 对象的引用,Car 的生命周期与 Engine 无关,Car 不管理 Engine 的销毁。Engine 对象由外部创建,可以在多个 Car 对象中共享,生命周期由外部管理。

结论:

聚合(Aggregation) 关系中,Car 并不负责 Engine 对象的生命周期。无论是通过构造函数、setter 方法,还是集合类型,Car 都只是持有 Engine 对象的引用,并利用它来执行功能。Engine 对象的生命周期独立于 Car,由外部代码控制,可以在多个容器对象(如多个 Car 实例)之间共享。

相关文章:

  • 每天五分钟深度学习PyTorch:向更深的卷积神经网络挑战的ResNet
  • 2025年中职大数据应用与服务竞赛培训方案分享
  • 算法系列之广度优先搜索解决妖怪和尚过河问题
  • Gazebo不报错但是没有机器人模型
  • 《Operating System Concepts》阅读笔记:p203-p207
  • 【redis】全局命令exists、del、expire、ttl(惰性删除和定期删除)
  • Java 深度复制对象:从基础到实战
  • Pytorch 第八回:卷积神经网络——GoogleNet模型
  • Vue 框架深度解析:源码分析与实现原理详解
  • C++修炼之路:初识C++
  • Cpu100%问题(包括-线上docker服务以及Arthas方式进行处理)
  • Android networkSecurityConfig 代码配置
  • Hadoop八股
  • Redis|Springboot集成Redis
  • React基础之useInperativehandlle
  • 【前端】【vue-i8n】【element】Element 框架国际化配置指南:从 element-ui 到 element-plus
  • 运行OpenManus项目(使用Conda)
  • 国家二级运动员证书有什么用·棒球1号位
  • QP 问题(Quadratic Programming, 二次规划)
  • QEMU源码全解析 —— 块设备虚拟化(2)
  • 重庆做网站好的公司/外贸业务推广
  • 建筑网站设计/高端营销型网站建设
  • 济南网站建设与维护/临沂seo推广外包
  • 做外汇关注的网站/seo门户网站
  • 做视频网站的备案要求/免费b站推广网站不
  • 做网站老师/网络促销策略