标签: spring framework
2015-09-01 13:43 918人阅读 评论(0) 收藏 举报
 分类:
Spring FrameWork(7) 

版权声明:本文为博主原创文章,未经博主允许不得转载。

spring IoC容器 根据基于xml的配置元数据(configuration metadata),使用反射机制来创建Bean的实例。

创建的方法有三种:

1. 通过构造器<constructor-arg/>

1.1 使用空构造器进行定义。类中必须有空构造器(可以是默认的)

空构造器中没有传入参数,bean的配置只需要一个定义名就可以了。

<bean id="beanID" class="com.szse.beans.HelloApiImpl "> </bean>

例子:

接口HelloApi.Java

  1. package com.szse.beans;
  2. public interface HelloApi {
  3. public void sayHello();
  4. }

它的实现类HelloApiImpl.java

  1. package com.szse.beans;
  2. public class HelloApiImpl implements HelloApi{
  3. private int num;
  4. private String message;
  5. public HelloApiImpl(){
  6. num = 1;
  7. message = "Hello world!";
  8. }
  9. @Override
  10. public void sayHello() {
  11. System.out.println(num + ":" + message);
  12. }
  13. }
配置文件HelloWorld.xml
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns="http://www.springframework.org/schema/beans"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans-4.2.xsd">
  6. <bean id="firstBean" class="com.szse.beans.HelloApiImpl ">
  7. </bean>
  8. </beans>
单元测试类TestHello.java
  1. package com.szse.beans;
  2. import org.junit.Test;
  3. import org.springframework.context.ApplicationContext;
  4. import org.springframework.context.support.ClassPathXmlApplicationContext;
  5. public class TestHello {
  6. @Test
  7. public void testInstantiatingBeanByConstructor() {
  8. //使用构造器
  9. ApplicationContext ctx =
  10. new ClassPathXmlApplicationContext("HelloWorld.xml");
  11. HelloApi firstBean = ctx.getBean("firstBean", HelloApi.class);
  12. firstBean.sayHello();
  13. }
  14. }
输出 1:Hello world!
 
1.2 带参构造器,类中有带参的构造方法
①根据参数索引(index)
<bean id="beanID" class="com.szse.beans.HelloApiImpl "> 
      <constructor-arg  index=" " value=" "/>
</bean>
index表示构造器的第几个参数,从0开始,value即为该参数的值。
例子:
在HelloApiImpl.java添加
  1. public HelloApiImpl(int num,String message){
  2. this.num = num;
  3. this.message = message;
  4. }
在HelloWorld.xml文件中添加
  1. <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
  2. <constructor-arg index="0" value="2" />
  3. <constructor-arg index="1" value="Hello spring!" />
  4. </bean>

在TestHello.java的测试方法,保留第一个例子作为对比

  1. @Test
  2. public void testInstantiatingBeanByConstructor() {
  3. //使用构造器
  4. ApplicationContext ctx =
  5. new ClassPathXmlApplicationContext("HelloWorld.xml");
  6. HelloApi firstBean = ctx.getBean("firstBean", HelloApi.class);
  7. firstBean.sayHello();
  8. HelloApi secondBean = ctx.getBean("secondBean", HelloApi.class);
  9. secondBean.sayHello();
  10. }

输出1:Hello world!
       2:Hello spring!

②根据参数类型(type)

将上面的secondBean配置改为如下

  1. <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
  2. <constructor-arg type="int" value="2" />
  3. <constructor-arg type="java.lang.String" value="Hello spring!" />
  4. </bean>

若是java基础类型,type可以直接指定该类型,其他都要用全类名。

测试方法不变,大家可以自己运行一遍试试结果是否一样。

③根据参数名(name)

将上面的secondBean配置改为如下

  1. <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
  2. <constructor-arg name="num" value="2" />
  3. <constructor-arg name="message" value="Hello spring!" />
  4. </bean>

测试方法不变,大家可以自己再运行一遍试试结果是否一样。

注:这里解释顺便给大家加深一下 对 “bean的实例是由IoC容器主动创建,而不是由我们自己创建”  这句话的理解。可以在构造器中加上System.out.println(”print sth…")。

测试方法中只保留这一句:

ApplicationContext ctx = 
    new ClassPathXmlApplicationContext("HelloWorld.xml");

运行输出,看看是不是我们xml文件中配置了几个bean就会打印出几个“print sth…”。

所以,ApplicationContext加载XML文件时就会创建好所有bean的实例,我们用的时候只需要getBean()就可以了。

2. 使用静态工厂方法

<bean id="beanID" class="com.szse.beans.HelloApiStaticFactory"factory-method="newInstance">

</bean>

注意这里的class属性是静态工厂类,而不是该bean的类。使用factory-method属性来确定哪个静态工厂方法创建的bean实例。

Spring调用工厂方法(也可以包含一组参数),并返回一个有效的对象。如果静态工厂方法需要参数,使用<constructor-arg>元素传入。

例子

静态工场类HelloApiStaticFactory.java

  1. package com.szse.beans;
  2. public class HelloApiStaticFactory {
  3. //工厂方法
  4. public static HelloApi newInstance(int num,String message) {
  5. //返回需要的Bean实例
  6. return new HelloApiImpl(num,message);
  7. }
  8. }

xml中加上

  1. <bean id="thirdBean" class="com.szse.beans.HelloApiStaticFactory" factory-method="newInstance">
  2. <constructor-arg name="num" value="3" />
  3. <constructor-arg name="message" value="Hello Jane!" />
  4. </bean>

测试类中加上方法

  1. @Test
  2. public void testInstantiatingBeanByFactory() {
  3. //使用工场方法
  4. ApplicationContext ctx =
  5. new ClassPathXmlApplicationContext("HelloWorld.xml");
  6. HelloApi thirdBean = ctx.getBean("thirdBean", HelloApi.class);
  7. thirdBean.sayHello();
  8. }

输出结果:3:Hello Jane!

3. 使用实例工场方法

先定义实例工厂Bean

<bean id="instanceFactoryBean" class="InstanceFactory全类名"/>

再使用实例工厂Bean创建我们需要的Bean,注意这里没有class属性了。若要传入指定方法参数,则和使用构造器方式一样。
<bean id="fourthBean" factory-bean="instanceFactoryBean" factory-method="newInstance"> </bean>

例子

实例工厂类HelloApiInstanceFactory.java

  1. package com.szse.beans;
  2. public class HelloApiInstanceFactory {
  3. public HelloApi newInstance(int num,String message) {
  4. return new HelloApiImpl(num,message);
  5. }
  6. }

xml文件中加入

  1. <bean id="instanceFactoryBean" class="com.szse.beans.HelloApiInstanceFactory"/>
  2. <bean id="fourthBean" factory-bean="instanceFactoryBean" factory-method="newInstance">
  3. <constructor-arg name="num" value="4" />
  4. <constructor-arg name="message" value="Hello Tom!" />
  5. </bean>

测试方法testInstantiatingBeanByFactory加入

  1. HelloApi fourthBean = ctx.getBean("fourthBean", HelloApi.class);
  2. fourthBean.sayHello();

输出结果 4:Hello Tom!

这三种实例化Bean的方式只是配置不一样,从获取方式看完全一样。这三种方式都是基于XML配置文件,脱离xml文件

Spring容器还有基于注解(Annotation)的方式来创建Bean,这个我们以后会讲到。

实例化Bean的方法(基于xml配置)-http://blog.csdn.net/shymi1991/article/details/48153293的更多相关文章

  1. JSON.parseObject将json字符串转换为bean类,是否大小写敏感区分---https://blog.csdn.net/mathlpz126/article/details/80684034

    JSON.parseObject将json字符串转换为bean类,是否大小写敏感区分 https://blog.csdn.net/mathlpz126/article/details/80684034

  2. XML操作:1.XML类(http://blog.csdn.net/happy09li/article/details/7460521)

    XML绑定TreeView private void XmlOperation_Load(object sender, EventArgs e) { path = AppDomain.CurrentD ...

  3. [环境搭建]-Web Api搭建到IIS服务器后PUT请求返回HTTP Error 405.0 - Method Not Allowed 解决方法 转摘:http://blog.csdn.net/qiujuer/article/details/23827531

    尝试使用微软的Web Api,他的确是一个很有意思的东西. 让我体会到了许多的方便,但是我发现部署到IIS服务器上去了后PUT和Delete请求将返回405. 原因是IIS的默认处理程序默认情况下只允 ...

  4. Spring3.2 中 Bean 定义之基于 XML 配置方式的源码解析

    Spring3.2 中 Bean 定义之基于 XML 配置方式的源码解析 本文简要介绍了基于 Spring 的 web project 的启动流程,详细分析了 Spring 框架将开发人员基于 XML ...

  5. 转-spring-boot 注解配置mybatis+druid(新手上路)-http://blog.csdn.net/sinat_36203615/article/details/53759935

    spring-boot 注解配置mybatis+druid(新手上路) 转载 2016年12月20日 10:17:17 标签: sprinb-boot / mybatis / druid 10475 ...

  6. 基于eclipse的mybatis映射代码自动生成的插件http://blog.csdn.net/fu9958/article/details/7521681

    基于eclipse的mybatis映射代码自动生成的插件 分类: JAVA 数据库 工具相关2012-04-29 00:15 2157人阅读 评论(9) 收藏 举报 eclipsegeneratori ...

  7. maven 依赖文件 pom.xml 编译 mvn compile 运行 不用mvn exec:java -Dexec.mainClass="hello.HelloWorld" 打成jar包 mvn package mvn install http://blog.csdn.net/yaya1943/article/details/48464371

    使用maven编译Java项目 http://blog.csdn.net/yaya1943/article/details/48464371  使用"mvn clean"命令清除编 ...

  8. Nginx 配置location root 转自https://blog.csdn.net/rofth/article/details/78581617

    nginx指定文件路径有两种方式root和alias,root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上. 最基本的区别 ...

  9. Golang拼接字符串的5种方法及其效率_Chrispink-CSDN博客_golang 字符串拼接效率 https://blog.csdn.net/m0_37422289/article/details/103362740

    Different ways to concatenate two strings in Golang - GeeksforGeeks https://www.geeksforgeeks.org/di ...

随机推荐

  1. vgg_face人脸识别

    最近参考http://blog.csdn.net/hlx371240/article/details/51388022一文,用LFW数据集对vgg_face.caffemodel进行fine-tune ...

  2. 两个星期,用Flutter撸个APP

    前言 Flutter是Google推出的跨平台的解决方案,Slogan是"Design beautiful apps",国内也有知名企业在使用和推广,例如阿里.美团都有在尝试. 个 ...

  3. WdatePicker设置日期范围

    设置 结束日期不超过当天日期:设置 开始日期不超过结束日期:设置 开始日期默认显示当月1日的日期,结束日期显示当天日期?<label>开始日期:</label><inpu ...

  4. 如何运行.ipynb文件

    首先cmd下面输入: pip install jupyter notebook ,安装慢的改下pip的源为国内的源 然后cmd中输入: jupyter notebook就会弹出一个页面 先upload ...

  5. Linux内核源码目录说明

    Linux内核源代码位于/usr/src/linux目录下,其结构分布如图1.3所示,每一个目录或子目录可以看作一个模块,其目录之间的连线表示“子目录或子模块”的关系.下面是对每一个目录的简单描述. ...

  6. [PyTorch]论文pytorch复现中遇到的BUG

    目录 1. zip argument #1 must support iteration 2. torch.nn.DataParallel 3. model.state_dict() 1. zip a ...

  7. nodejs v8引擎

    Node.js 线程你理解的可能是错的 本文代码运行环境 系统:MacOS High Sierra Node.js:10.3.0 复制代码 Node.js是单线程的,那么Node.js启动后线程数是1 ...

  8. pairs 和 ipairs异同

    同:都是能遍历集合(表.数组) 异:ipairs 仅仅遍历值,按照索引升序遍历,索引中断停止遍历.即不能返回 nil,只能返回数字 0,如果遇到 nil 则退出.它只能遍历到集合中出现的第一个不是整数 ...

  9. java中字面量,常量和变量之间的区别(附:Integer缓存机制)

    一.引子 在各种教科书和博客中这三者经常被引用,今天复习到内存区域,想起常量池中就是存着字面量和符号引用,其实这三者并不是只在java中才有,各个语言中都有类似的定义,所以做一下总结,以示区分. 二. ...

  10. 通过git-bash一句话获得当前目录的全部csproj文件绝对路径

    #!/usr/bin/env bash %.sh}.txt 保存为 csprojfilelist.sh,注意换行符使用LF,如果git-bash关联了sh文件,直接双击就可以得到csprojfilel ...