01-Spring-ioc理解
2017-10-24 20:14
211 查看
转自:http://blog.csdn.net/frightingforambition/article/details/48374903
对Spring有所了解的都应该知道,spring贯穿始终的两个重要的思想,一个是IOC(控制反转),一个是DI(依赖注入)。
耦合性:在java中表现为类之间的关系,耦合性强说明类之间的依赖关系强;
侵入性:框架对代码的侵入,比如你项目用了stuts1,要改框架时发现改的东西太多了,比如actionForm等,所以struts1对代码的侵入性是很高的。
在传统的java开发中具有高度的耦合性和侵入性。一个项目中,一般一个类都要依赖很多其他的类来完成自己的操作,我们往往采用new这个类的对象来调用他的方法,这样两个类的依赖关系太强,改一个地方,往往牵扯很多类牵扯大量的代码。侵入性上一段的例子可以明白。当然EJB也可以解决耦合性和侵入性的问题,但是ejb太依赖服务器,属于重量级的框架。
可以说在这样的背景下,spring应运而生,一个轻量级的框架,解决传统企业开发的复杂性;使用普通的javaBean代替EJB技术。可以管理对象和对象之间的依赖关系,我们不需要自己建立对象,把这部分工作全部转交给容器完成,具有低耦合,对代码没有侵略性,对服务器没有依赖性特点的框架。
而这个容器,即IOC.
事实上,使用ioc方式创建对象的目的,是为了以“被动”的方式形成对象之间的依赖关系。传统的开发过程中,不管是new,还是普通工厂,都需要目标对象主动创建、主动查找其需要的依赖对象 , 目标对象会将他的精力分散在不必要的非业务逻辑方面。IOC通过DI(依赖注入)把建立好的对象注入到目标对象中。
spring IOC容器的关键点:
必须将被管理的对象定义到spring配置文件中
必须定义构造函数或setter方法,让spring将对象注入过来
4000
pring ioc的实现。本例使用spring 3.2
这样就实现了spring ioc思想。
对Spring有所了解的都应该知道,spring贯穿始终的两个重要的思想,一个是IOC(控制反转),一个是DI(依赖注入)。
首先我们要知道在程序开发中为什么要使用spring框架
这里先引入两个概念:耦合性:在java中表现为类之间的关系,耦合性强说明类之间的依赖关系强;
侵入性:框架对代码的侵入,比如你项目用了stuts1,要改框架时发现改的东西太多了,比如actionForm等,所以struts1对代码的侵入性是很高的。
在传统的java开发中具有高度的耦合性和侵入性。一个项目中,一般一个类都要依赖很多其他的类来完成自己的操作,我们往往采用new这个类的对象来调用他的方法,这样两个类的依赖关系太强,改一个地方,往往牵扯很多类牵扯大量的代码。侵入性上一段的例子可以明白。当然EJB也可以解决耦合性和侵入性的问题,但是ejb太依赖服务器,属于重量级的框架。
可以说在这样的背景下,spring应运而生,一个轻量级的框架,解决传统企业开发的复杂性;使用普通的javaBean代替EJB技术。可以管理对象和对象之间的依赖关系,我们不需要自己建立对象,把这部分工作全部转交给容器完成,具有低耦合,对代码没有侵略性,对服务器没有依赖性特点的框架。
而这个容器,即IOC.
如何理解IOC思想
一个很流行的例子,我换了种说法,这样更好理解:好比找女朋友,普通的方式是我们依赖各种关系找到这个女朋友(相当于new了对象),有一天分手了,而以前的那些关系也没有了,要想找到新的女朋友就要依赖新的关系(重新 new另外一个对象),可以想象这个过程很麻烦。于是有了一种新的方式找对象——婚介所,这里就是我们所说的IOC方式,你把你要求的对象的特征告诉婚介所,他会直接给你找到一对象,没有中间复杂的过程,你只管相处的事情就好了,new的过程不用管,不需要任何依赖关系,即使哪天要换了,再把需要的对象提交给婚介所就行了,你就会得到你想要的新的对象了。事实上,使用ioc方式创建对象的目的,是为了以“被动”的方式形成对象之间的依赖关系。传统的开发过程中,不管是new,还是普通工厂,都需要目标对象主动创建、主动查找其需要的依赖对象 , 目标对象会将他的精力分散在不必要的非业务逻辑方面。IOC通过DI(依赖注入)把建立好的对象注入到目标对象中。
Spring IOC具体如何实现
上文中的婚介所就是ioc管理对象的容器,实际上是一个xml文件,将对象配置在xml里面,通过spring的工厂类进行解析,以“反射”的方式创建对象。spring IOC容器的关键点:
必须将被管理的对象定义到spring配置文件中
必须定义构造函数或setter方法,让spring将对象注入过来
例子
我们可以通过下面这里例子理解s4000
pring ioc的实现。本例使用spring 3.2
1.配置applicationContext.xml
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd"> <bean id="userDao4MySqlImpl" class="com.bjsxt.spring.dao.UserDao4MySqlImpl"/> <bean id="userDao4OracleImpl" class="com.bjsxt.spring.dao.UserDao4OracleImpl"/> <bean id="userManager" class="com.bjsxt.spring.manager.UserManagerImpl"> <!-- 构造方法注入 <constructor-arg ref="userDao4OracleImpl"/> --> <!-- setter方法注入 --> <property name="userDao" ref="userDao4OracleImpl"/> </bean> </beans>
2.注入的类:
package com.bjsxt.spring.dao; public interface UserDao { public void save(String username, String password); } package com.bjsxt.spring.dao; public class UserDao4MySqlImpl implements UserDao { public void save(String username, String password) { System.out.println("--------UserDao4MySqlImpl.save()-------"); } } package com.bjsxt.spring.dao; public class UserDao4OracleImpl implements UserDao { public void save(String username, String password) { System.out.println("--------UserDao4OracleImpl.save()-------"); } }
3.被注入的类:
package com.bjsxt.spring.manager; public interface UserManager { public void save(String username, String password); } package com.bjsxt.spring.manager; import com.bjsxt.spring.dao.UserDao; public class UserManagerImpl implements UserManager { /** * 两种方式:如果这个类中需要注入对象,先建立对象属性, * 在写构造方法或者settet方法。 * */ private UserDao userDao; /* public UserManagerImpl(UserDao userDao) { this.userDao = userDao; } */ public void save(String username, String password) { this.userDao.save(username, password); } public void setUserDao(UserDao userDao) { this.userDao = userDao; } }
4.测试类:
package com.bjsxt.spring.client; import org.springframework.beans.factory.BeanFactory; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.bjsxt.spring.manager.UserManager; public class Client { public static void main(String[] args) { /* 传统的通过new对象建立类之间的关系 * UserManager userManager = new UserManagerImpl(new UserDao4OracleImpl()); UserManager userManager = new UserManagerImpl(new UserDao4MySqlImpl()); userManager.save("张三", "123");*/ /** * IOC思想 通过工厂类解析xml文件,以“反射”的方式创建对象: */ BeanFactory factory = new ClassPathXmlApplicationContext("applicationContext.xml"); UserManager userManager = (UserManager)factory.getBean("userManager"); userManager.save("张三", "123"); /** * IOC思想 实际的执行过程,这也是为什么需要setter方法或构造方法的原因: */ // UserManagerImpl userManager = new UserManagerImpl(); // userManager.setUserDao(new UserDao4MySqlImpl()); // userManager.save("张三", "123"); } }
这样就实现了spring ioc思想。
相关文章推荐
- 谈谈对Spring IOC(控制反转)的理解--转
- Spring中IoC和AOP的理解
- AOP与IOC,简单理解spring
- 深入理解Spring的两大特征(IOC和AOP)
- 如何理解spring中的IOC和AOP
- Spring AOP详解 (转) 以及IOC(个人理解)
- Spring之IOC思想的理解和简单实现
- 谈谈对Spring IOC的理解
- Spring IoC原理理解
- Spring面试:IOC和AOP的理解
- Spring技术内幕之IOC容器的实现(01)-IOC容器初始化过程
- Spring IoC(控制反转)和DI(依赖注入)的理解
- 谈谈对Spring IOC的理解
- Spring面试,IoC和AOP的理解
- 01 走进Spring,Context、Bean和IoC
- 番外 01:Spring IoC 实现原理简析,Java的反射机制,通过类名创建对象
- 我所理解的spring ioc容器
- 谈谈对Spring IOC的理解
- Spring核心内容IOC和DI的理解
- Spring学习笔记(一)----理解IOC