创建应用对象之间协作关系的行为通常成为装配,该篇的主要内容有两个,一个Spring装配Bean的几种方式以及Spring表达式,事实上这两者是分不开的,在Spring中,对象无需自己负责查找或者创建与其关联的其它对象,相反容器负责把须要相互协作的对象一引用赋予各个对象,眼下我们先说声明式的装配,注解式的装配等溜到下篇再具体记录,在声明用的xml配置文件里,能够使用表达式来完毕一些简单的逻辑处理,和方法调用或者对象引用,在有些特殊的需求其中非它莫属,首先是装配Bean

声明Bean

<bean id="duke" class="com.springinaction.springidol.Juggler"/ >

该语句在Spring容器中声明了一个类型为com.springinaction.springidol.Juggler的对象,使用id为duke来引用该对象,这里说一句,在Spring容器中,对象之间的引用都是通过依赖注入的方式引用的,也就是说是通过xml配置文件来配置类和类之间的关系。

通过构造器注入

<bean id="duke" class="com.springinaction.springidol.Juggler" >
<constructor-arg value="15"/>
</bean>

在Juggler类中有一个仅仅有一个入參的构造器,參数类型是int,我们通过<bean>标签下的<constructor-arg>标签来定义入參的值,假设没有该标签,那么Spring容器将会调用Juggler类的默认构造器,假设该类中存在多个构造器,那么Spring容器依据传入的參数个数以及类型选择參数数量组多的那个构造器

上边的样例仅仅为Juggler类注入了一个简单值的參数,也就是String加上基本数据类型,假设參数类型是一个复杂类型的话,能够先生命一个该类型的Bean,然后在构造器注入的时候引用该类,例如以下

<bean id="duke" class="com.springinaction.springidol.Juggler" >
<constructor-arg value="15"/>
<constructor-arg ref="sonnet29"></constructor-arg>
</bean> <bean id="sonnet29" class="com.springinaction.springidol.Sonnet29"/>

注意在第二个參数上把value属性换成了ref,ref的值是声明的某个Bean的id引用

通过工厂方法创建Bean

有时候静态工厂方法是实例化对象的唯一方法,比方说在使用单例模式的情况下,整个应用仅仅同意有一个某类型的对象,这个时候就能够使用工厂方法创建Bean了,可是在类中须要提供静态的工厂方法来获得实例,下面是一个单例的样例,详细变量的含义不用太在意,仅仅是说一下创建的方式

package com.springinaction.springidol;

public class Stage {

	private Stage() {

	}

	private static class StageSingoletonHolder {
static Stage instance = new Stage();
} public static Stage getInstance() {
return StageSingoletonHolder.instance;
}
}

这个类中的静态工厂方法是getInstance(),在配置应用上下文文件的时候,就不能依照正常方式声明Bean了,由于不能再通过构造方法来创建对象,Spring提供了一个factory-method 属性,能够定义Bean的静态工厂方法,配置例如以下

<bean id="stage" class="com.springinaction.springidol.Stage"
factory-method="getInstance" />

在创建容器的时候Spring机会通过getInstance创建对象了



Bean的作用域

在声明Bean的时候能够设置Bean的作用域,眼下这个阶段用到的就仅仅有两个属性值,其它的等到兴许碰到的时候再来学习,请看例如以下两个配置

<bean id="duke" class="com.springinaction.springidol.Juggler"
scope="singleton" /> <bean id="duke" class="com.springinaction.springidol.Juggler"
scope="prototype" />

singleton代表在该Spring容器中这个定义的Bean仅仅能有一个实例,prototype代表在该Spring容器其中每次调用方法获得Bean的时候多会生成一个新的实例,有必要讨论一下的就是singleton,假设没有设置scope,那么该值就是默认值,主要想说一下这个单一实例的含义,该单例跟上述静态工厂方法的单例是截然不同的,该单例方式是针对于Spring容器的也就是应用上下文中的单例,在调用应用上下文对象的getBean()方法获得指定的bean的时候假设没有设置prototype值,那么应用上下文对象就会从容器中找到已经生成好的该Bean的对象返回回来,假设设置了prototype值,那么在每次调用getBean的时候都会生成一个新的Bean对象。假设其它的应用上下文中也有声明该类型的Bean那么也会在其它应用上下文中穿件新的对象,甚至实在同一个应用上下文中定义了两个该类型的Bean也会生成两个对象,仅仅只是id引用不一样而已,所以说这并非纯粹上的单例模式。

初始化和销毁Bean

实例化一个Bean或者从容器中移除一个Bean的时候可能须要做一些额外的处理,所以Spring提供了定义初始化和销毁时候的方法配置例如以下

<bean id="duke" class="com.springinaction.springidol.Juggler"
init-method="turnOnLights" destroy-method="turnOffLights" />

init-method属性定义了Bean初始化时候调用的方法,destrory-method属性定义了Bean销毁时调用的方法,假设为每个Bean都声明这种两个方法未免太过麻烦,所以Spring还提供过了定义默认初始和销毁方法配置例如以下

<?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-3.0.xsd"
default-init-method="turnOnLights"
default-destroy-method="turnOffLights"></beans>

在beans标签中定义default-init-method和default-destroy-method方法在期中定义的Bean中,每一个bean的默认初始化和销毁方法都会是上边定义的两个方法。

注入Bean属性

通常javaBean的属性都是私有属性,仅仅能通过对应的getter和setter方法,Spring的注入属性的方法也是通过配置xml配置文件,先来说一说有注入的方式,再来看详细的配置方法。

注入Bean的属性是通过<property>标签来完毕,属性分为一下几种:

*注入简单值(String或者基本数据类型)

*注入其它的Bean(注入同样类型的已经是声明的bean)

*注入内部Bean(类似于内部类)

*注入集合

*注入空值

下面的配置文件将会一次展示上述的注入方式,配置文件例如以下

	<bean id="duke" class="com.springinaction.springidol.Juggler">
<!-- 注入简单值 -->
<property name="property1" value="property"></property>
<property name="property2" value="15"></property>
<!-- 注入其它Bean -->
<property name="property3" ref="property3"></property>
<!-- 注入内部Bean -->
<property name="property4" >
<bean class="com.springinaction.springidol.Property4"/>
</property>
<!-- 注入空值 -->
<property name="property5" ><null/></property>
<!-- 注入集合 -->
<!-- List -->
<property name="List">
<list>
<value>item1</value>
<ref bean="item2"/>
<bean class="com.springinaction.springidol.Item3"/>
<null/>
</list>
</property>
<!-- Set -->
<property name="Set">
<set>
<value>item1</value>
<ref bean="item2"/>
<bean class="com.springinaction.springidol.Item3"/>
<null/>
</set>
</property>
<!-- Map -->
<property name="Map">
<map>
<entry key="item1" value="item1"/>
<entry key="item1" value-ref="item2"/>
<entry key-ref="item3" value="item3"/>
</map>
</property>
<!-- Properties -->
<property name="props">
<props>
<prop key="item1">item1</prop>
</props>
</property>
</bean>

从上往下整理一遍<property>标签中name属性代表的是Bean中属性的名称,value值代表的属性值,可是仅仅能表示简单的值,ref能够引用一个已经声明的Bean,值是Bean的id,在引用简单值的时候Spring会依据属性的详细类型做自己主动的类型转换,所以我们看第二个注入值是一个字符串“15”,可是属性的类型是int。

我们能够在属性内部声明一个Bean当作是属性的值,这就是所说的注入内部Bean,该Bean仅仅在属性标签内才实用,和内部类的特性比較像,可是不能像内部类一样创建一个静态公开的内部类,能够在类以外调用,在Spring中内部bean是不能被外部引用的。

Spring提供了注入控值的配置,也就是给属性注入null值使用<null/>标签。

假设属性的类型是集合,我们不必去集成一个集合类然后通过注入bean的方式注入,能够直接利用Spring提供的集合标签来注入。

首先是List由标签<list>表示,在该标签中有四种表示值的方式,我都已经列出来了,简单值、Bean引用、内部Bean、空值。

再是Set 由标签<set>表示,set和list的作用差点儿相同,可是在set中不能出现反复的值

然后是Map由标签<map>表示,该标签下的<entry>标签表示的是map中的一个元素,分别有一下四种属性值key、key-ref、value、value-ref,map的键值能够是不论什么类型的值,简单值使用不带ref后缀的属性,Bean引用使用带ref后缀的属性引入Bean。

最后是Properties由标签<props>表示,props中的键值仅仅能是String类型的值,<prop>代表了Properties中的一个元素,详细配置方法见上边的配置演示样例。

Spring实战笔记2---Bean的装配的更多相关文章

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

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

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

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

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

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

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

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

  5. Spring4学习笔记 - 配置Bean - 自动装配 关系 作用域 引用外部属性文件

    1 Autowire自动装配 1.1 使用:只需在<bean>中使用autowire元素 <bean id="student" class="com.k ...

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

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

  7. Spring学习笔记--注入Bean属性

    这里通过一个MoonlightPoet类来演示了注入Bean属性property的效果. package com.moonlit.myspring; import java.util.List; im ...

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

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

  9. Spring学习笔记(3)——Bean的注入方式

    依赖注入 依赖注入支持属性注入.构造函数注入.工厂注入. 属性注入: 属性注入即通过setXxx()方法注入Bean的属性值或依赖对象 属性注入要求Bean提供一个默认的构造函数(无参构造函数),并为 ...

随机推荐

  1. sed 技巧一例:特定位置插入

    通过一例子熟悉 sed 的运用 下面命令是在修改 ~/fs/install/nzos.conf 文件, 并在 env 第一次出现的地方再添加一行 env LXC_EXTRA_PORT=5556 sed ...

  2. Canny边缘检測算法原理及其VC实现具体解释(一)

    图象的边缘是指图象局部区域亮度变化显著的部分,该区域的灰度剖面一般能够看作是一个阶跃,既从一个灰度值在非常小的缓冲区域内急剧变化到还有一个灰度相差较大的灰度值.图象的边缘部分集中了图象的大部分信息,图 ...

  3. 我觉得主要靠积累,难度不是问题,主要靠时间积累,以及兴趣带来的学习能力(我觉得至少5年全职Qt开发经验,才能算精通)

    顺便想请教一下,你用QT有几年了? 3年不到 那感觉怎么样?是比较难,还是不难但需要时间才能掌握全部? 很多东西真的要拿来做项目了,才会懂.要靠积累.一开始看看理论貌似都很简单. 但是QT和C++本身 ...

  4. boost:asio编译

    参考:http://hi.baidu.com/need_for_dream/blog/item/c14a28086a504c33e92488b5.html 环境: VS2010, boost1.38. ...

  5. cocos2d-x lua 内存回收

    使用cocos2d-x lua架构,游戏中存在两种内存回收方式. 1.cocos2d-x 本身内存回收 PS:假设在lua在创建一个类,继承cocos2d-x的一个类A,则该A也遵循cocos2d-x ...

  6. 【deep learning学习笔记】注释yusugomori的LR代码 --- 模型测试

    测试部分代码: void test_lr() { srand(0); double learning_rate = 0.1; double n_epochs = 500; int train_N = ...

  7. iOS - NSLog的使用方法

    NSLog的定义 NSLog定义在NSObjCRuntime.h中,如下所示: void NSLog(NSString *format, …); 基本上,NSLog很像printf,同样会在conso ...

  8. DB2错误码解释对照

    表 2. SQLSTATE 类代码 类  代码    含义 要获得子代码,  参阅...  00 完全成功完成 表 3  01 警告 表 4  02 无数据 表 5  07 动态 SQL 错误 表 6 ...

  9. JavaFX游戏开发效率浅谈

    声明:   本博客文章原创类别的均为个人原创,版权所有.转载请注明出处: http://blog.csdn.net/ml3947,另外本人的个人博客:http://www.wjfxgame.com. ...

  10. Flume+LOG4J+Kafka

    基于Flume+LOG4J+Kafka的日志采集架构方案 本文将会介绍如何使用 Flume.log4j.Kafka进行规范的日志采集. Flume 基本概念 Flume是一个完善.强大的日志采集工具, ...