控制反转(IoC)是将对象创建与生命周期管理权交由容器接管的设计原则;依赖注入(DI)是IoC的主流实现方式,包括构造器、Setter、注解等注入形式;面向切面(AOP)则用于模块化横切关注点,如日志、事务等。

如果您在学习Spring框架或现代Java开发时遇到控制反转、依赖注入和面向切面这三个概念,却难以区分它们各自的关注点与作用边界,则可能是由于三者在实现层面存在交叠、在术语表述上又高度抽象。以下是厘清这三种核心编程思想的路径:
一、控制反转(IoC)——职责归属的重新分配
控制反转是一种设计原则,其本质是将对象的创建权和生命周期管理权从程序代码中剥离,交由外部容器(如Spring容器)统一接管,从而降低模块间的硬编码耦合。它不规定具体实现方式,而是定义“谁来控制流程”的哲学转变。
1、传统编程中,类A若需使用类B的实例,通常在A内部通过new B()直接创建;
2、采用IoC后,类A不再负责获取B,而是声明对B的需求,由容器在运行时主动将B的实例“注入”到A中;
3、此时程序主控权发生转移:控制权从应用程序代码移交至框架容器,故称“反转”。
二、依赖注入(DI)——IoC最主流的实现机制
依赖注入是控制反转的具体落地形式之一,它通过外部提供依赖对象的方式,消除类内部对具体实现类的直接引用,使依赖关系在运行期动态确立,而非编译期固化。
1、构造器注入:在Bean构造时通过构造参数传入依赖对象;
2、Setter注入:通过public setter方法接收依赖对象,要求被注入类提供对应方法;
3、接口注入:定义注入专用接口(如Injectable),由容器调用其注入方法——该方式在Spring中已基本弃用;
4、注解驱动注入(如@Autowired):由容器扫描注解并自动完成匹配与装配,无需显式编写XML配置或构造逻辑。
三、面向切面(AOP)——横切关注点的模块化封装
AOP并非替代OOP,而是对其的补充,用于将分散在多个类中、与核心业务逻辑无关但又必须执行的共性行为(如日志记录、事务控制、权限校验)提取为独立模块,即“切面”,再以声明式方式织入目标对象。
1、定义切面类,使用@Aspect标注,并在其中编写通知方法(@Before、@After、@Around等);
2、通过切点表达式(如execution(* com.example.service..*.*(..)))精确指定增强逻辑的织入位置;
3、启用AOP支持(如@EnableAspectJAutoProxy)使容器识别切面并生成代理对象;
4、当目标方法执行时,容器自动在指定连接点周围执行切面逻辑,原始业务代码无须修改。











