Spring IOC

[size=x-large] IOC 目的:降低类与类之间的依赖性、便于程序的可扩展性。
   方法:程序依赖于接口,调用是主动的将实现类传递过来。
在了解IOC之前、我们先说下传统的编程方法:

在传统的编程中,我们是通过在Action类中实例化DAO类对象、然后再调用DAO类中的方法;这样来实现对DAO层中的数据操作;但是、问题来了,当我们以后对这个程序升级时用这个Action类对另一个DAO类进行操作时、一般我们就需要重新实例化对象,然后再修改所调用的相应的方法;这样不仅降低了代码的质量、增加了代码冗余;而且对于解决升级所带来的问题也是不可能的。所以、我们在写程序时,所要思考的就是避免这种问题,让我们前期设计时、为后期的程序升级提供便利;然而,对于传统的这种编程思想来说想做到是不可能的;但是、如果我们让Action类依赖于接口的话、只需要在接口中定义抽象方法,然后让相应的类实现接口的具体方法,然而这里最关键的一步就是我们在Action中如何调用其方法;这也是IOC的重要一点、它的调用是通过接口实现类实例化好后放入Action的setter()方法中来接收所要调用的类中的方法;这样由对DAO类的依赖转变成对接口的依赖、让要实现的类实例化好后传给Action;于是便有传统的Action控制DAO中方法转变成DAO自己控制;这样就大大降低了类与类之间的依赖。这就是控制反转。这也就是Spring IOC的编程核心。

  Spring中的具体实现:在spring的配置文件中、我们先将要调用的类放进来;
  比如:这是将jdbc实现类和hibernate实现类都放在配置文件中、它们都是对数据库的操作、定义的id是唯一的、对应的class类是其绝对路径
[/size]


  <bean id="jdbcDAO" class="hn.spring.why.dao.TestJdbcDAO"/>
  
  <bean id="hibernateDAO" class="hn.spring.why.dao.TestHibernateDAO"/>

然后、我们再配置的就是Action调用哪种DAO类了;下面的ref便是要调用的id名
<bean id="testAction" class="hn.spring.why.TestAction">
<!-- 维护当前action类依赖的DAO实现类 -->
<property name="baseDAO" ref="jdbcDAO"/>
</bean>


以上这些配置使得在spring中将其配置的类都已经实例化好了、而且哪个ADO放入Action的setter方法中也已放好了、具体实现时只需要在需要调用的地方中解析spring的配置文件
如:


ApplicationContext ioc = new ClassPathXmlApplicationContext("applicationContext.xml");
然后在获取和调用
TestAction action = (TestAction)ioc.getBean("testAction");


[size=x-large]

这就是Spring IOC
最后补充一点、我们上面的setter()方法就是平常所说的依赖注入、除了setter方法外,我们还可以用构造方法将已实例化对象传到action中去。
在Spring中需要配置<constructor-arg ref=”jdbcDAO”/> 同时、在添加一个有参的构造函数;
最后、我们通过对spring IOC 的回顾可以发现、里面用到了单实例模式以及工厂模式;单实例模式就是我们的action每次被注入的都是同一个对象;但是、spring也为我们提供了多实例的方法,在bean中添加scope=”prototype”;这样它就由默认的scope=”singleton”变成了多实例模式了。而工厂模式就是Spring配置一个bean类,spring容器就会将他们实例化好、这就是一种抽象的工厂模式。
[/size]
### Spring IOC 原理及实现 #### 1. 控制反转(IOC)的概念 控制反转(Inversion of Control,简称 IOC)是一种设计思想,旨在将对象的创建和管理从应用程序代码中分离出来。通过 IOC,开发者无需手动管理对象的生命周期和依赖关系,而是由框架负责这些任务。这种思想使得开发者可以专注于业务逻辑的实现,而不需要关心对象之间的交互细节[^1]。 #### 2. 依赖注入(DI) 依赖注入(Dependency Injection,简称 DI)是实现 IOC 的一种方式。DI 的核心在于通过外部配置或注解的方式,将对象的依赖关系注入到目标对象中,而不是由对象自己负责依赖的创建和管理。依赖注入有三种主要形式:构造器注入、Setter 方法注入和字段注入[^4]。 #### 3. Spring IOC 容器的核心接口 Spring 框架提供了两种主要的 IOC 容器接口: - **BeanFactory**:这是 Spring 框架的基础接口,面向 Spring 内部使用。它负责配置、创建和管理 Bean 的生命周期。 - **ApplicationContext**:这是一个更高级的容器接口,面向开发者使用。它扩展了 BeanFactory 的功能,提供了更多的企业级特性,如国际化支持、事件传播等。在实际开发中,通常使用 ApplicationContext 而非 BeanFactory[^2]。 #### 4. Spring IOC 的实现方式 Spring IOC 的实现主要包括以下几个方面: ##### (1) 元数据解析 Spring 使用 XML 文件、Java 注解或 Java 配置类来定义 Bean 的元数据。例如,通过 `<bean>` 标签在 XML 文件中定义 Bean,或者使用 `@Component`、`@Service` 等注解在 Java 类上声明 Bean[^5]。 示例代码(XML 配置): ```xml <bean id="userDao" class="com.mayuanfei.springioc.dao.impl.UserDaoImpl" /> ``` 示例代码(注解配置): ```java @Component public class UserDaoImpl implements UserDao { // 实现方法 } ``` ##### (2) 依赖注入 Spring 通过反射机制解析 Bean 的依赖关系,并将其注入到目标对象中。以下是一个简单的依赖注入示例: 示例代码(字段注入): ```java @Service public class UserService { @Autowired private UserDao userDao; // 自动注入 UserDao } ``` ##### (3) 生命周期管理 Spring 容器会管理 Bean 的整个生命周期,包括初始化、运行时和销毁阶段。开发者可以通过实现特定的接口(如 `InitializingBean` 和 `DisposableBean`)或使用注解(如 `@PostConstruct` 和 `@PreDestroy`)来定制 Bean 的生命周期行为。 示例代码(生命周期管理): ```java @Component public class MyBean { @PostConstruct public void init() { System.out.println("Bean 初始化"); } @PreDestroy public void destroy() { System.out.println("Bean 销毁"); } } ``` ##### (4) 扩展机制 Spring 提供了丰富的扩展点,允许开发者自定义容器的行为。例如,通过实现 `BeanFactoryPostProcessor` 或 `BeanPostProcessor` 接口,可以在 Bean 初始化前后插入自定义逻辑[^4]。 #### 5. Spring IOC 的优势 Spring IOC 的核心优势包括: - **解耦**:对象之间不再直接依赖具体实现,而是通过接口或抽象类进行交互。 - **灵活性**:通过配置文件或注解动态管理 Bean,便于修改和扩展。 - **可维护性**:集中处理对象的创建和依赖关系,降低了代码复杂度。 ### 总结 Spring IOC 是一种通过容器管理对象生命周期和依赖关系的设计模式。其核心原理包括元数据解析、依赖注入、生命周期管理和扩展机制。通过这些机制,Spring 实现了对象控制权的反转,从而提高了系统的解耦性、灵活性和可维护性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值