2.1 回顾

对于我第一天在bean的装配中写的,是一些基本的语法或者是Spring本身的一些规定,但是我没有对此进行深究。接下来就让我们仔细的讨论一下细节问题。和传统的类的定义和方法的调用做一些比较。这样就会体现出Ioc的特点。 下面的UML图就是我之前定义的一个接口和自己的一个实现。

public interface CompactDisc {
void play();
} @Component
public class SgtPeppers implements CompactDisc {
private String title="享受孤独的音乐";
private String article="奏出和谐的篇章"; public void play() {
System.out.println(title+article);
}
}

下面是我的测试类

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = CDPlayConfig.class)
public class CDPlayerTest {
@Autowired
private CompactDisc cd; @Test
public void test(){
cd.play();
}

下面是我的配置文件

@Configuration
@ComponentScan
public class CDPlayConfig {
}

简单的回顾一下,CompactDisc加了注解@Component之后告诉Spring他自己是一个Bean.而通过@ComponeScan注解扫描到则会个Bean.然后注解@AutoWired自动注入。 基于注解的Bean的装配,我们可以用图的方式明确下:

2.2 基于Java注解的bean的装配

此时当我们去掉@ComponentScan注解之后,就会报出如下的错误:

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean found for dependency [cn.czg.test.CompactDisc]: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}

没有对应的bean被定义。因为失去了这个注解之后,就再也扫描不到了。此时我们也可以显式的完成这个功能。 现在大家看到了,失去了这个注解后会出现错误,此时我们可以基于Java注解的形式实现bean的自动装配;

很简单,Java提供了相应的注解,@Bean,一般用在方法的上面。 我们之前使用@ComponentScan注解完成扫描,自动的创建bean,但是此时我们将配置文件稍加改造即可。去掉扫描注解后报错,但是添加@Bean注解就可以啦

@Configuration
public class CDPlayConfig {
@Bean
public CompactDisc sgtPeppers(){
return new SgtPeppers();
}
}

无论如何,@Bean的作用就是为了获得接口的实力对象,我们在此方法中最终获取了对象实例。

@Bean
public IFoo getFooInstance(){
int floor =(int) Math.floor(Math.random() * 4);
if(floor==1){
return new FooDemo1();
}else if(floor==2){
return new FooDemo2();
}else {
return new FooDemo3();
}
}

大家可以看看,这个功能还是很厉害的,随着条件的不同,可以创建不同的实例对象。 以上就是基于Java的注解对Bean的装配,现在如果我的CDPalyer需要sgtpapers对象,该怎么办呢?此时我们还是基于注解的配置:且看以下的代码:

@Configuration
public class CDPlayerConfig {
@Bean
public CompactDisc compactDisc() {
return new SgtPeppers();
}
@Bean
public CDPlayer cdPlayer() {
return new CDPlayer(compactDisc());
}
}

2.3 基于Java注解的注入(构造器注入/属性注入)

上面的代码恰好完成了ComoactDisc的注入。需要说明的是:CDPlayer对象的构造器似乎在调用了方法compactsic();从而返回一个SgtPapers对象的实例。但是在Spring中,由于@Bean注解的存在,却是阻止了方法的调用,直接返回该方法创建的实例对象SgtPapers.假如说上述的代码再修改一下:

@Configuration
public class CDPlayerConfig {
@Bean
public CompactDisc compactDisc() {
return new SgtPeppers();
}
@Bean
public CDPlayer cdPlayer() {
return new CDPlayer(compactDisc());
}
@Bean
public CDPlayer anotherCdPlayer() {
return new CDPlayer(compactDisc());
}
}

这样的话,如果说还是按照普通的方法进行调用,那么由于每一个构造CDPlayer的构造器传入了不相同的CompactDisc对象,因此就会产生多个CDPlayer对象,而Spring终的bean默认都是单例的。确保只要哪一个应用需要这个bean,都可以唯一的注入这个相同的bean.

@Bean
public CDPlayer cdPlayer(CompactDisc compactDisc){
return new CDPlayer(compactDisc);
}

也许上述的代码看起来会更加的直观一点。这其实通过cdPlay()方法传入一个CompactDisc对象,通过构造器完成注入。而且和@Bean CompactDisc没有直接的关系。 代码稍加改造,就是setter属性的注入:

@Bean
public CDPlayer cdPlayer(CompactDisc compactDisc){
CDPlayer cdPlayer=new CDPlayer(compactDisc);
cdPlayer.setCompactDisc(compactDisc);
return cdPlayer;
}

2.4 基于xml对bean的装配

这个就比较简单了。比如要装配CDPlayer:

<?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";>
<!--声明bean,构造器注入了compactDisc对象-->
<bean id="cdPlayer" class="cn.czg.bean.CDPlayer">
<constructor-arg ref="compactDisc"/>
</bean>
<!--声明compactDisc的实例-->
<bean id="compactDisc" class="cn.czg.bean.SgtPeppers"/>
</beans>

2.5 导入混合配置

在启动Spring的时候,需要将所有的bean加载到Spring容器当中,我们上面的bean在CDPlayerConfig类中进行了配置,但是并不是所有的bean都需要在这个类中进行配置bean,而且如果配置在一起,整个配置类会显示的及其笨重。比如现在我需要自己定义另外一个配置类,加载不同的bean:

@Configuration
public class CDConfig {
@Bean
public CompactDisc compactDisc(){
return new Sgtpapers();
}
}

但是最终的,还是要在一个最终的配置文件中将其引入。@Import注解此时大显神威。

@Configuration
@ComponentScan
@Import(CDConfig.class)
public class CDPlayerConfig {
@Bean
public CDPlayer compactDisc(CompactDisc compactDisc){
return new CDPlayer(compactDisc);
}
}

还可以将两个配置类组合在一起,组成一个新的配置类

@Configuration
@Import({CDConfig.class,CDPlayerConfig.class})
public class SoundSystemConfig {
}

在这里我们定义BlankDisc,同样的也是实现了接口CompactDisc.

public class BlankDisc implements CompactDisc {

    private String title;
private String artist;
private List<String> tracks; public BlankDisc(String title, String artist, List<String> tracks) {
this.title = title;
this.artist = artist;
this.tracks = tracks;
} public void play() {
System.out.println("Playing " + title + " by " + artist);
for (String track : tracks) {
System.out.println("-Track: " + track);
}
}
}

此时我们不希望使用@Bean的方式去装配这个bean,而是希望通过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"; xmlns:c="http://www.springframework.org/schema/c";
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd";>
<bean id="blankDisc" class="cn.czg.soundsystem.BlankDisc"
c:_0="Sgt.Paper's lonely Hearts Club Blank"
c:_1="The Beatles">
<constructor-arg>
<list>
<value>Sgt.Paper's lonely Hearts Club Blank</value>
<value>Hgsd oijdasfjsa oiasf </value>
<value>sdfq sgtfq t hyt</value>
<value>sdfq sgtfq t hytsdarf</value>
</list>
</constructor-arg>
</bean>
</beans>

在上述的配置中,c:_0或者c:_1中的0和1就是索引,也就是多参数的情况下使用的一种方式,比如上述的字段title和article这两个字段就可以这样写。value可以更加灵活的说明。下面的是List中的参数的值。此时我们也希望将配置文件和XML共同的加载到Spring文件中,此时就用ImportSource注解

@Configuration
@ComponentScan
@Import(CDConfig.class)
@ImportResource("classpath:applicationContext.xml")
public class CDPlayerConfig {
@Bean
public CDPlayer compactDisc(CompactDisc compactDisc){
return new CDPlayer(compactDisc);
}
}

2.5 在XML 中引入JavaConfig

此时我们的配置类直接以bean的方式配置就可以啦

《Spring实战》系列之Bean的装配-Days02的更多相关文章

  1. Spring MVC系列-(2) Bean的装配

    2. Bean的装配 Spring容器负责创建应用程序中的bean,并通过DI来协调对象之间的关系.Spring提供了三种主要的装配机制: XML显式配置: Java配置类进行显式配置: 隐式的bea ...

  2. Spring MVC系列-(3) Bean的装配

    3. 高级装配Bean 3.1 Bean的作用域 默认情况下,Spring中的bean都是以单例的形式存在的,无论注入多少次,每次注入的都是同一个实例. 考虑到某些bean可能是可变的,Spring定 ...

  3. #Spring实战第二章学习笔记————装配Bean

    Spring实战第二章学习笔记----装配Bean 创建应用对象之间协作关系的行为通常称为装配(wiring).这也是依赖注入(DI)的本质. Spring配置的可选方案 当描述bean如何被装配时, ...

  4. 《Spring实战》系列之Bean的装配-Days01

    1 自动化装配bean Spring通过两个方面实现对bean的自动装配 1 ) 组件扫描(component scaning):Spring会自动发现Spring上下文中的bean 2 ) 自动装配 ...

  5. spring实战四之Bean的自动装配(注解方式)

    使用注解装配: 从spring2.5开始,Spring启用了使用注解自动装配Bean的属性,使用注解方式自动装配与在XML中使用 autowire 属性自动装配并没有太大区别,但是使用注解方式允许更细 ...

  6. spring实战二之Bean的自动装配(非注解方式)

    Bean的自动装配 自动装配(autowiring)有助于减少甚至消除配置<property>元素和<constructor-arg>元素,让Spring自动识别如何装配Bea ...

  7. spring实战五之Bean的自动检测

    在spring实战四中,使用在Spring中增加<context:annotation-config>的方式告诉Spring,我们打算使用基于注解的自动装配,希望Spring特殊对待我们所 ...

  8. Spring学习记录(三)---bean自动装配autowire

    Spring IoC容器可以自动装配(autowire)相互协作bean之间的关联关系,少写几个ref autowire: no ---默认情况,不自动装配,通过ref手动引用 byName---根据 ...

  9. Spring学习日志之Bean的装配

    Spring容器负责创建应用程序中的bean并通过依赖注入来协调这些对象之间的关系.但是,作为开发人员,要告诉Spring需要创建哪些bean并且如何将其装配在一起.当描述bean如何装配时,Spri ...

随机推荐

  1. 写出pythonic的python代码

    http://www.cnblogs.com/dadadechengzi/p/6226071.html 1,列表推导(没当要对序列中的内容进行循环处理时,就应该尝试使用列表推倒) 在python中编写 ...

  2. MySQL 创建索引(Create Index)的方法和语法结构及例子

    MySQL 创建索引(Create Index)的方法和语法结构及例子 MySQL 创建索引(Create Index)的方法和语法结构及例子   CREATE INDEX Syntax CREATE ...

  3. 95th percentile concentration

    很多网络流量监控软件都提供了一个95th的值,开始一直不太理解,终于在solarwinds官网找到答案. 95th百分点指的是所给数集中超过其95%的数.它是一个统计学上的概念.对于某个接口,准确统计 ...

  4. 蓝牙通讯 ble

    http://blog.csdn.net/beijingshi1/article/details/36426829

  5. Openldap- 大机群身份验证服务

    无论在哪个行业,数据安全永远都是摆在首要地位.尤其是在大数据行业上,谁掌握了数据,谁就有可能成为下个亿万富豪的环境中,数据安全更为重要.大数据的安全可以从哪些地方入手,首先可以在身份验证上面入手.在大 ...

  6. 分享知识-快乐自己:Nginx概述及如何使用

    概述: 什么是 Nginx? Nginx (engine x) 是一款轻量级的 Web 服务器 .反向代理服务器及电子邮件(IMAP/POP3)代理服务器. 什么是反向代理? 反向代理(Reverse ...

  7. 分享知识-快乐自己:idea的断点调试

    1:Step Over ,进入下一步,如果是方法,那就直接跳过(F8) 2:Step Into,进入下一步,如果是方法,就进入方法内部,但是不会进入jdk封装的方法.(F7) 3:Force Step ...

  8. 数据结构C语言版干货------->线性表之顺序表

    一:头文件定义 /*************************************************************************** *项目 数据结构 *概要 逻辑 ...

  9. 8th

    2017-2018-2 20179212<网络攻防实践>第8周作业 视频学习 Kali权限维持之后门 权限维持包含Tunnel工具集.Web后门.系统后门三个子类.其中系统后门与web后门 ...

  10. [转]前端网络(性能)监测工具berserkJS

    berserkJS 是基于 Qt (C++跨平台库)开发的前端网络(性能)监测工具. 它的核心功能是通过内置 webkit 收集由页面实际网络请求相关数据. 偏重于页面上线前检测与评估. 页面性能分析 ...