开源框架Spring详解---IoC控制反转(一)
开源框架Spring详解---IoC控制反转(一) spring在英文里有春天、弹簧、跳跃和泉眼的意思。Spring 也表示是一个开源框架,是为了解决企业应用程序开发复杂性由Rod Johnson创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 J2EE 应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。 Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。 目的:解决企业应用开发的复杂性 功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能 范围:任何Java应用 简单来说,Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。 轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。 控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。 面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。 容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。 框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。 所有Spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。它们也为Spring中的各种模块提供了基础支持。 下面就搭建一个简单的Spring项目:1、首先要引入Spring的jar包。Spring有两个jar包:spring.jarcommons-logging.jar2、然后写一个xml文件,这个xml文件可以随便起名字,但是Spring的官方网站就是写的是applicationContext.xml.所以我们最好也写成application.xml Xml代码 <?xml version="1.0" encoding="UTF-8"?> <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-2.0.xsd"> <!-- 配置一个bean 指明bean id class property属性 value属性值 加载这个文件的时候 进行初始化 (需要根据bean的配置)--> <bean id="greetingServiceImpl" class="cn.csdn.service.GreetingServiceImpl"> <!-- 通过构造器参数的索引位置匹配方法 索引位置从0开始 <constructor-arg index="0"> <value>z_xiaofei168</value> </constructor-arg> <constructor-arg index="1"> <value>你好!</value> </constructor-arg> --> <!-- 通过构造器的参数类型匹配方法进行注入 --> <constructor-arg type="java.lang.String"> <value>你好!</value> </constructor-arg> <constructor-arg type="java.lang.String"> <value>z_xiaofei168</value> </constructor-arg> <!-- 通过set方法进行注入,必须在你类中有对应的set方法 <property name="say"> <value>你好!</value> </property> --> </bean> </beans> 3、再次写service层: GreetingService.java Java代码 package cn.csdn.service; public interface GreetingService { public void say(); } GreetingServiceImpl.java Java代码 package cn.csdn.service; public class GreetingServiceImpl implements GreetingService { /**私有属性*/ private String say; /**在定义一个私有的属性*/ private String name; /** * IOC依赖注入的方式 * 2、通过构造器注入 * */ public GreetingServiceImpl(String name,String say){ this.name=name; this.say=say; } @Override public void say() { System.out.println("你给"+name+"打的招呼是:"+say); } /** * IOC依赖注入的方式 * 1、通过setter方法实现的 * */ /**set方法进行初始化的工作*/ public void setSay(String say){ this.say=say; } } 4、最后写个测试类来测试: Java代码 package cn.csdn.junit; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.context.support.FileSystemXmlApplicationContext; import cn.csdn.service.GreetingService; public class GreetingTest { /**测试GreetingServiceImpl的方法*/ @Test public void test1(){ /**加载spring容器 可以解析多个配置文件 采用数组的方式传递*/ ApplicationContext ac = new ClassPathXmlApplicationContext(new String[]{"applicationContext.xml"}); /**IOC的控制反转体现*/ GreetingService greetingService = (GreetingService) ac.getBean("greetingServiceImpl"); greetingService.say(); } @Test public void test2(){ ApplicationContext ac = new FileSystemXmlApplicationContext(new String[]{"src/applicationContext.xml"}); /**IOC的控制反转体现*/ GreetingService greetingService = (GreetingService) ac.getBean("greetingServiceImpl"); greetingService.say(); } } 5、在控制台的显示结果是: 你给z_xiaofei168打的招呼是:你好!
?