一:这里先说一下DI(Dependency Injection)依赖注入有种表现形式:一种是CI(Constructor Injection)构造方法注入,另一种是SI(Set Injection) set 注入。这篇随笔讲的是第一种构造方法注入(Constructor Injection).

其实DI(Dependency Injection)依赖注入你不妨反过来读:注入依赖也就是把"依赖"注入到一个对象中去。那么何为"依赖"呢?依赖就是讲一个对象初始化或者将实例化的时候需要另一个对象,我们把另一个对象成为"依赖"。如构造方法注入(Constructor Injection)就是把依赖当做构造方法的参数注入进去的。如:

//Injection B to A. 我们把B称为依赖。一般情况下B是一个接口,这符合面向接口编程的规范。

public A (B b){

}

二:使用依赖注入的好处是什么?

  1.DI(Dependency Injection)最大的好处是decoupling(解耦)。如上面的代码把B注入给A如果B是一个接口或者抽象类。只要任何一个类实现或者继承B都可以注入给A.因此可以达到解耦的目的。

  2. 依赖注入给谁?        

dependencies injected into the objects that need them.(依赖注入给那些需要他们的对象。)

3.在spring中怎么让依赖传入到被依赖的对象(看上面的代码:怎么把B传入到A中)?

 在这里我引用一下spring in action中的一段文字:(注:我下面的示例代码基本跟spring in action 的一样)

The big question here is,how can you give SlayDragonQuest to BraveKnight ? And how can you give a PrintStream to SlayDragonQuest?

The act of creating associations between application components is commonly referred to as wiring.

spring通过配置配置文件,配置bean的形式,完成装配,又装配实现把依赖注入给需要他们的对象中的。

【我这里还想说明一下配置文件中的一个bean其实就对应一个javabean,也就是一个pojo对象,bean就是javabean的缩写形式而已】

示例代码的目录结构如下图所示:

  上面中的带两个圈的配置文件想说明两个问题:

一个是:new ClassPathXmlApplicationContext("spring-julysecond.xml");//注意这个.xml文件是在src目录下。

    new ClassPathXmlApplicationContext("com/config/spring-julythird.xml")//注意这个.xml文件在com.cofig这个文件下。

另一个问题是DI的解耦问题:spring-julysecond.xml文件中注入的是SlayDragonQuest,spring-julythird.xml注入的是SearchHillQuest.在不改变代码的情况下看传入的Quest的实现类不同,从而打出的结果不同。

spring-julysecond.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.xsd">
<!--this is constructor injection-->
<!--the act of creating associations between application components is commonly referred to
as wiring-->
<bean id="knight" class="com.qls.impl.BraveKnight">
<!-- collaborators and configuration for this bean go here -->
<constructor-arg ref="query"></constructor-arg>
</bean>
<bean id="query" class="com.qls.impl.SlayDragonQuest">
<!-- collaborators and configuration for this bean go here -->
<constructor-arg value="#{T(System).out}"/>
</bean>
<!-- more bean definitions go here -->
</beans>

//spring-julythird.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.xsd">
<!--this is constructor injection-->
<!--the act of creating associations between application components is commonly referred to
as wiring-->
<bean id="knight" class="com.qls.impl.BraveKnight">
<!-- collaborators and configuration for this bean go here -->
<constructor-arg ref="query"></constructor-arg>
</bean>
<bean id="query" class="com.qls.impl.SearchHillQuest">
<constructor-arg value="#{T(System).out}"/>
</bean>
<!-- more bean definitions go here -->
</beans>

//Query接口的代码如下:

 package com.qls.inter;

 /**
* Created by ${秦林森} on 2017/6/2.
*/
public interface Query {
void query();
void embark();
}

//Knight的代码如下:

 package com.qls.inter;

 /**
* Created by ${秦林森} on 2017/6/2.
*/
public interface Knight {
void embarkOnQuest();
}

//Query接口的实现类的代码如下:

//首先是:SlayDragonQuest的代码如下:

 package com.qls.impl;

 import com.qls.inter.Query;

 import java.io.PrintStream;

 /**
* Created by ${秦林森} on 2017/6/2.
*/
public class SlayDragonQuest implements Query{
private PrintStream stream; public SlayDragonQuest(PrintStream stream) {
this.stream = stream;
}
@Override
public void embark(){
stream.println("Embarking on quest to slay the dragon");
stream.println("ouyangfeng is the most beautiful woman in the world.");
}
@Override
public void query(){
System.out.println("slay dragon quest");
}
}

//其次是SearchHillQuest的代码如下:

 package com.qls.impl;

 import com.qls.inter.Query;

 import java.io.PrintStream;

 /**
* Created by ${秦林森} on 2017/6/3.
*/
public class SearchHillQuest implements Query{
private PrintStream stream; public SearchHillQuest(PrintStream stream) {
this.stream = stream;
} @Override
public void query() { } @Override
public void embark() {
stream.println("the hero search the hill where the damsel was missing");
}
}

//BraveKnight的代码如下:

 package com.qls.impl;

 import com.qls.inter.Knight;
import com.qls.inter.Query;
import org.springframework.context.annotation.Configuration; /**
* Created by ${秦林森} on 2017/6/2.
*/ public class BraveKnight implements Knight{
private Query query; public BraveKnight(Query query) {
this.query = query;
} @Override
public void embarkOnQuest() {
query.embark();
}
}

//测试类的代码如下:

 package com.qls.test;

 import com.qls.inter.Knight;
import org.springframework.context.support.ClassPathXmlApplicationContext; /**
* Created by ${秦林森} on 2017/6/2.
*/
public class Test {
public static void main(String[] args) {
/**
* 加载配置文件的方式:在src下直接写配置文件的名即可,
* 不直接在src下要把前面的包名加上。包名的前面可加也可以不加斜杠/
*/
// ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("/com/config/spring-julythird.xml");
// ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("com/config/spring-julythird.xml");
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring-julysecond.xml");
Knight knight = context.getBean(Knight.class);
knight.embarkOnQuest();
context.close(); }
}

spring in action学习笔记一:DI(Dependency Injection)依赖注入之CI(Constructor Injection)构造器注入的更多相关文章

  1. Spring in Action 学习笔记二-DI

    装配bean 2015年10月9日 9:49             Sprng中,对象无需自己负责查找或创建其关联的其他对象.相关,容器负责吧需要相互协作的对象引用赋予各个对象. 创建应用对象之间协 ...

  2. Spring in Action 学习笔记一

    Spring 核心       Spring的主要特性仅仅是 依赖注入DI和面向切面编程AOP       JavaBean 1996.12 Javav 规范针对Java定义了软件组件模型,是简单的J ...

  3. spring in action学习笔记十五:配置DispatcherServlet和ContextLoaderListener的几种方式。

    在spring in action中论述了:DispatcherServlet和ContextLoaderListener的关系,简言之就是DispatcherServlet是用于加载web层的组件的 ...

  4. spring in action 学习笔记十四:用纯注解的方式实现spring mvc

    在讲用纯注解的方式实现springmvc之前先介绍一个类:AbstractAnnotationDispatcherServletInitializer.这个类的作用是:任何一个类继承AbstractA ...

  5. Spring in Action 学习笔记三-AOP

    面向切面的Spring 2015年10月9日 11:30             屏幕剪辑的捕获时间: 2015-10-9 14:30             屏幕剪辑的捕获时间: 2015-10-9 ...

  6. spring in action学习笔记十六:配置数据源的几种方式

    第一种方式:JNDI的方式. 用xml配置的方式的代码如下: 1 <jee:jndi-lookup jndi-name="/jdbc/spittrDS" resource-r ...

  7. spring in action 学习笔记九:如何证明在scope为prototype时每次创建的对象不同。

    spring 中scope的值有四个:分别是:singleton.prototype.session.request.其中session和request是在web应用中的. 下面证明当scope为pr ...

  8. spring in action学习笔记七:@Conditional注解的用法

    @Profile注解是@Conditional注解的一个例子.即@Profile也是用@Conditional注解来实现的. 必须让条件实现Condition这个接口. 下面的案例讲如果环境中有mag ...

  9. spring in action 学习笔记五:@Autowired这个注解如何理解

    @Autowired这个注解的意思就是自动装配.他把一个bean对象自动装配到另一个对象中.下面的案例证明了spring的自动装配. 定义一个Sixi类.代码如下: package com.qls.a ...

随机推荐

  1. netty-socket.io点对点通讯和聊天室通讯

    netty-socketio是基于netty的socket.io服务实现,可以无缝对接前端使用的socketio-client.js. 相对于javaee的原生websocket支持(@serverE ...

  2. php学习【1】

    1:输出语句 <?php echo "hellow world"; print "hellow world"; print_r ("helow ...

  3. 申请qq第三方登录 http://www.php20.com/forum.php?mod=viewthread&tid=29 (出处: 码农之家)

    百度  qq互联  进入网站 按图中的步骤申请第三方登录即可 先申请成为开发者 审核通过后再继续操作 提交 后列表中会出现提交的申请. 状态为审核中,审核通过会得到下图. 点查看 红线后面就是appi ...

  4. POJ 3581 三段字符串(后缀数组)

    Sequence Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 7923   Accepted: 1801 Case Tim ...

  5. linux-shell——01

    没有什么好的标题,只是一些随笔.我用的是linux虚拟机,red hat 7 一:nat模式使得虚拟机可以访问外网,但是这种模式下只可以访问外网,但外面的不能访问里面 首先将虚拟机的网络连接改为nat ...

  6. Numpy 索引及切片

    1.一维数组的索引及切片 ar = np.arange(20) print(ar) print(ar[4]) print(ar[3:6]) print(ar[:4:2]) #索引到4 按2的步长 pr ...

  7. 寻找物体的凸包 opencv

    凸包的含义: 在二维平面上给定点集,凸包就是将最外层的点连接起来构成的凸多边形.并且这个凸多边形能包含点集中所有的点.OPENCV中: convexHull函数用于寻找图像点集中的凸包.它有六个输入参 ...

  8. dategrip破解

    https://blog.csdn.net/weixin_39428938/article/details/81078806

  9. Aizu:2170-Marked Ancestor

    Marked Ancestor Time limit 8000 ms Memory limit 131072 kB Problem Description You are given a tree T ...

  10. java线程安全(单例模式)(转载)

    原文链接:http://www.jameswxx.com/java/%E8%AF%B4%E8%AF%B4%E5%8D%95%E4%BE%8B%E6%A8%A1%E5%BC%8F/ 单例模式?多么简单! ...