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

版权声明:本文为博主原创文章,未经博主允许不得转载。
spring IoC容器 根据基于xml的配置元数据(configuration metadata),使用反射机制来创建Bean的实例。
创建的方法有三种:
1. 通过构造器<constructor-arg/>
1.1 使用空构造器进行定义。类中必须有空构造器(可以是默认的)
空构造器中没有传入参数,bean的配置只需要一个定义名就可以了。
<bean id="beanID" class="com.szse.beans.HelloApiImpl "> </bean>
例子:
接口HelloApi.Java
- package com.szse.beans;
- public interface HelloApi {
- public void sayHello();
- }
它的实现类HelloApiImpl.java
- package com.szse.beans;
- public class HelloApiImpl implements HelloApi{
- private int num;
- private String message;
- public HelloApiImpl(){
- num = 1;
- message = "Hello world!";
- }
- @Override
- public void sayHello() {
- System.out.println(num + ":" + message);
- }
- }
配置文件HelloWorld.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns="http://www.springframework.org/schema/beans"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-4.2.xsd">
- <bean id="firstBean" class="com.szse.beans.HelloApiImpl ">
- </bean>
- </beans>
单元测试类TestHello.java
- package com.szse.beans;
- import org.junit.Test;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- public class TestHello {
- @Test
- public void testInstantiatingBeanByConstructor() {
- //使用构造器
- ApplicationContext ctx =
- new ClassPathXmlApplicationContext("HelloWorld.xml");
- HelloApi firstBean = ctx.getBean("firstBean", HelloApi.class);
- firstBean.sayHello();
- }
- }
输出 1:Hello world!1.2 带参构造器,类中有带参的构造方法①根据参数索引(index)<bean id="beanID" class="com.szse.beans.HelloApiImpl "><constructor-arg index=" " value=" "/></bean>index表示构造器的第几个参数,从0开始,value即为该参数的值。例子:在HelloApiImpl.java添加
- public HelloApiImpl(int num,String message){
- this.num = num;
- this.message = message;
- }
在HelloWorld.xml文件中添加
- <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
- <constructor-arg index="0" value="2" />
- <constructor-arg index="1" value="Hello spring!" />
- </bean>
在TestHello.java的测试方法,保留第一个例子作为对比
- @Test
- public void testInstantiatingBeanByConstructor() {
- //使用构造器
- ApplicationContext ctx =
- new ClassPathXmlApplicationContext("HelloWorld.xml");
- HelloApi firstBean = ctx.getBean("firstBean", HelloApi.class);
- firstBean.sayHello();
- HelloApi secondBean = ctx.getBean("secondBean", HelloApi.class);
- secondBean.sayHello();
- }
输出1:Hello world!
2:Hello spring!②根据参数类型(type)
将上面的secondBean配置改为如下
- <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
- <constructor-arg type="int" value="2" />
- <constructor-arg type="java.lang.String" value="Hello spring!" />
- </bean>
若是java基础类型,type可以直接指定该类型,其他都要用全类名。
测试方法不变,大家可以自己运行一遍试试结果是否一样。
③根据参数名(name)
将上面的secondBean配置改为如下
- <bean id="secondBean" class="com.szse.beans.HelloApiImpl ">
- <constructor-arg name="num" value="2" />
- <constructor-arg name="message" value="Hello spring!" />
- </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
- package com.szse.beans;
- public class HelloApiStaticFactory {
- //工厂方法
- public static HelloApi newInstance(int num,String message) {
- //返回需要的Bean实例
- return new HelloApiImpl(num,message);
- }
- }
xml中加上
- <bean id="thirdBean" class="com.szse.beans.HelloApiStaticFactory" factory-method="newInstance">
- <constructor-arg name="num" value="3" />
- <constructor-arg name="message" value="Hello Jane!" />
- </bean>
测试类中加上方法
- @Test
- public void testInstantiatingBeanByFactory() {
- //使用工场方法
- ApplicationContext ctx =
- new ClassPathXmlApplicationContext("HelloWorld.xml");
- HelloApi thirdBean = ctx.getBean("thirdBean", HelloApi.class);
- thirdBean.sayHello();
- }
输出结果: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
- package com.szse.beans;
- public class HelloApiInstanceFactory {
- public HelloApi newInstance(int num,String message) {
- return new HelloApiImpl(num,message);
- }
- }
xml文件中加入
- <bean id="instanceFactoryBean" class="com.szse.beans.HelloApiInstanceFactory"/>
- <bean id="fourthBean" factory-bean="instanceFactoryBean" factory-method="newInstance">
- <constructor-arg name="num" value="4" />
- <constructor-arg name="message" value="Hello Tom!" />
- </bean>
测试方法testInstantiatingBeanByFactory加入
- HelloApi fourthBean = ctx.getBean("fourthBean", HelloApi.class);
- fourthBean.sayHello();
输出结果 4:Hello Tom!
这三种实例化Bean的方式只是配置不一样,从获取方式看完全一样。这三种方式都是基于XML配置文件,脱离xml文件
Spring容器还有基于注解(Annotation)的方式来创建Bean,这个我们以后会讲到。
实例化Bean的方法(基于xml配置)-http://blog.csdn.net/shymi1991/article/details/48153293的更多相关文章
- JSON.parseObject将json字符串转换为bean类,是否大小写敏感区分---https://blog.csdn.net/mathlpz126/article/details/80684034
JSON.parseObject将json字符串转换为bean类,是否大小写敏感区分 https://blog.csdn.net/mathlpz126/article/details/80684034
- XML操作:1.XML类(http://blog.csdn.net/happy09li/article/details/7460521)
XML绑定TreeView private void XmlOperation_Load(object sender, EventArgs e) { path = AppDomain.CurrentD ...
- [环境搭建]-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的默认处理程序默认情况下只允 ...
- Spring3.2 中 Bean 定义之基于 XML 配置方式的源码解析
Spring3.2 中 Bean 定义之基于 XML 配置方式的源码解析 本文简要介绍了基于 Spring 的 web project 的启动流程,详细分析了 Spring 框架将开发人员基于 XML ...
- 转-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 ...
- 基于eclipse的mybatis映射代码自动生成的插件http://blog.csdn.net/fu9958/article/details/7521681
基于eclipse的mybatis映射代码自动生成的插件 分类: JAVA 数据库 工具相关2012-04-29 00:15 2157人阅读 评论(9) 收藏 举报 eclipsegeneratori ...
- 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"命令清除编 ...
- Nginx 配置location root 转自https://blog.csdn.net/rofth/article/details/78581617
nginx指定文件路径有两种方式root和alias,root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上. 最基本的区别 ...
- 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 ...
随机推荐
- 528. Random Pick with Weight
1. 问题 给定一个权重数组w,w[i]表示下标i的权重,根据权重从数组中随机抽取下标. 2. 思路 这道题相当于 497. Random Point in Non-overlapping Recta ...
- TED #06# Questioning the universe
Stephen Hawking: Questioning the universe 1. 第一段: There is nothing bigger or older than the universe ...
- c++第十八天
p105~p108: 1.迭代器与数组的不同:迭代器的索引值必须是无符号类型,数组的索引无此要求. 2.使用数组的时候编译器一般会把它转化为指针. 3.auto ia2(数组名);的结果是:获得一个指 ...
- 《Java入门第二季》第四章 多态
Java 中的多态1.引用的多态:意思就是父类的句柄既可以持有本类的对象,也可以持有子类的对象. 2.方法的多态:注意点是当父类句柄持有子类对象的时候,无法调用子类特有的方法. 多态中的引用类型转换1 ...
- Vue学习笔记之Vue学习前的准备工作
0x00 起步 1.扎实的HTML/CSS/Javascript基本功,这是前置条件. 2.不要用任何的构建项目工具,只用最简单的<script>,把教程里的例子模仿一遍,理解用法.不推荐 ...
- 参考sectools,每个人至少查找5种安全工具、库等信息并深入研究至少两种并写出使用教程
1.Nessus Nessus是免费网络漏洞扫描器,它可以运行于几乎所有的UNIX平台之上.它不仅能永久升级,还免费提供多达11000种插件(但需要注册并接受EULA-acceptance--终端用户 ...
- hdu 5683 zxa and xor 暴力
zxa and xor Time Limit: 16000/8000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Pro ...
- python 返回列表中的偶数
def is_even_num(l): enum = [] for n in l: == : enum.append(n) return enum print(is_even_num([, , , , ...
- 用 profvis 进行性能分析
Rprof( ) 函数提供了有用的信息帮助我们找到代码瓶颈,进而提升代码性能.RStudio 也发布了一个增强版的分析工具 profvis( ),它还提供了用于分析 R 代码的交互式可视化功能(htt ...
- 使用向量化的 if:ifelse
进行分支计算的一个替代方法是 ifelse( ).这个函数接收一个逻辑向量作为判定条件,并且返回一个向量.对于逻辑判定条件内的每一个元素,若是 TRUE,则选择第 2个参数 yes 中所对应的元素:若 ...