spring中只有两大核心技术:

控制反转(IOC)&依赖注入(DI),AOP(面向切面编程)

依赖注入:指利用配置文件的关系,来决定类之间的引用关系,以及数据的设置操作。

构造方法注入

默认在applicationContext文件中配置的程序都可以自动通过spring容器加载时自动对对象实例化。

但是自动进行初始化的时候,调用的是类中的无参构造方法,而且通过反射机制可以知道,无参构造方法一定比有参构造方法的实例化更容易。

但是spring简化了反射的处理机制。利用spring中的动态的特性可以直接明确调用构造方法参数。

构造注入之前的文章已经有了,这里只补充前面没有的内容。

02-spring学习-配置bean

除了有之前的通过index,参数类型配置bean。

还能使用参数名称描述构造方法

Dept类:

package com.Spring.Demo;

import java.beans.ConstructorProperties;

public class Dept {

    private Integer deptno;
private String name; @ConstructorProperties(value={"paramDeptno","paramDeptName"})
public Dept(Integer deptno, String name) {
this.deptno = deptno;
this.name = name;
}
@Override
public String toString() {
return "Dept [deptno=" + deptno + ", name=" + name + "]";
}
}

调用这个方法:

package com.Spring.Demo;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class TestDept { public static void main(String[] args) { ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
Dept dept=ctx.getBean("dept",Dept.class);
System.out.println(dept);
} }

Dept.java类 设置参数名称:

@ConstructorProperties(value={"paramDeptno","paramDeptName"})
public Dept(Integer deptno, String name) {
this.deptno = deptno;
this.name = name;
}

也就是说设置的时候可以使用paramDeptno来代替索引0,paramDeptName代替索引1。

利用参数名称进行设置:

    <bean id="dept" class="com.Spring.Demo.Dept">
<constructor-arg name="paramDeptno" value="10" ></constructor-arg>
<constructor-arg name="paramDeptName" value="开发部门" ></constructor-arg>
</bean>

真使用构造方法,还是使用参数的类型和顺序编写比较方便。

setter和getter注入

指通过属性的getter和setter方法,在配置中配置属性名称值。

具体看这里的各种属性配置

03-spring学习-属性配置细节

但是这里补充一点,对应布尔值类的设置,在spring中支持以下几种方式:

true/false,1/0,on/off,yes/no。

如果类中属性是boolean(注意首字母小写)型数据,返回的时候一般建议使用is开头(如下面例子isClose),但是也可以使用getter命名。

例子:

Dept类:

package com.Spring.Demo;

import java.beans.ConstructorProperties;

public class Dept {

    private Integer deptno;
private String name;
private boolean close; public boolean isClose() {
return close;
} public void setClose(boolean close) {
this.close = close;
} public Integer getDeptno() {
return deptno;
} public void setDeptno(Integer deptno) {
this.deptno = deptno;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} @Override
public String toString() {
return "Dept [deptno=" + deptno + ", name=" + name + ", close=" + close + "]";
} }

调用:

        ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
Dept dept=ctx.getBean("dept",Dept.class);
System.out.println(dept);

参数配置:

    <bean id="dept" class="com.Spring.Demo.Dept">
<property name="deptno" value="34"></property>
<property name="name" value="开发部门"></property>
<property name="close" value="no"></property>
</bean>

上面使用no配置Boolean属性,运行结果:

Dept [deptno=34, name=开发部门, close=false]

注入集合数据

支持:数组,LIST,Set,Map,properties。

同样看前面文档里面的连接。

这里做点补充:

一,操作数组注入:

company类:

package com.Spring.Demo;

import java.util.Arrays;

public class Company {

    private String msg[];
private Integer data[];
public String[] getMsg() {
return msg;
}
public void setMsg(String[] msg) {
this.msg = msg;
}
public Integer[] getData() {
return data;
}
public void setData(Integer[] data) {
this.data = data;
}
@Override
public String toString() {
return "Company [msg=" + Arrays.toString(msg) + ", data=" + Arrays.toString(data) + "]";
}
}

配置:

    <bean id="company" class="com.Spring.Demo.Company">
<property name="data">
<array value-type="java.lang.Integer">
<value>10</value>
<value>20</value>
<value>30</value>
</array>
</property>
<property name="msg">
<array value-type="java.lang.String">
<value>mldn</value>
<value>java-mldn</value>
</array>
</property>
</bean>

我们发现,在使用数组数据的时候,设置了相应的数据类型,如果不写操作类型,那么spring会自动判断给出的数据类型,帮助用户自动转型

调用:

package com.Spring.Demo;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class TestCompany { public static void main(String[] args) {
ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
Company cmp=ctx.getBean("company",Company.class);
System.out.println(cmp);
} }

运行结果:

Company [msg=[mldn, java-mldn], data=[10, 20, 30]]

但是需要清楚,数组一般不会在开发中出现,如果真出现,使用List集合横向代替数组

Set和List注入:

假如上面集合类型是数组类型是List类型,就应该换成这样:

    <bean id="company" class="com.Spring.Demo.Company">
<property name="data">
<list value-type="java.lang.Integer">
<value>10</value>
<value>20</value>
<value>30</value>
</list>
</property>
<property name="msg">
<list value-type="java.lang.String">
<value>mldn</value>
<value>java-mldn</value>
</list>
</property>
</bean>

如果使用Set类型,配置也是如上,不需要改变,但是List和Set有个区别,Set集合里面的数据会自动去除重复。

注入Map集合:

company类:

package com.Spring.Demo;
import java.util.Map; public class Company { private Map<Integer,String> msg; public Map<Integer, String> getMsg() {
return msg;
} public void setMsg(Map<Integer, String> msg) {
this.msg = msg;
} @Override
public String toString() {
return "Company [msg=" + msg + "]";
} }

配置:

    <bean id="company" class="com.Spring.Demo.Company">
<property name="msg">
<map key-type="java.lang.Integer" value-type="java.lang.String">
<entry key="1" value="mldn"></entry>
<entry key="2" value="java"></entry>
</map>
</property>
</bean>

执行结果:

Company [msg={1=mldn, 2=java}]

以上的操作实际上见到的不多,而真正见过最多的是properties类型

Properties注入:

company类:

package com.Spring.Demo;
import java.util.Properties; public class Company { private Properties msg; public Properties getMsg() {
return msg;
} public void setMsg(Properties msg) {
this.msg = msg;
} @Override
public String toString() {
return "Company [msg=" + msg + "]";
}
}

配置如下:

    <bean id="company" class="com.Spring.Demo.Company">
<property name="msg">
<props>
<prop key="mdln">mldn.com</prop>
<prop key="java">java.com</prop>
</props>
</property>
</bean>

在一些框架整合中,此类属性的设置(properties)是最为常见的。

内部引用

现在所给出的实际上是只是定义一些数值,而最神奇的是他可以定义文件内部的引用关系。

观察如下结构:

假如一个公司有很多部门,所有在公司类里面加入一个部门集合变量。

package com.Spring.Demo;
import java.util.List;
import java.util.Properties; public class Company { private Properties msg;
private List<Dept> depts; public Properties getMsg() {
return msg;
} public void setMsg(Properties msg) {
this.msg = msg;
} public List<Dept> getDepts() {
return depts;
} public void setDepts(List<Dept> depts) {
this.depts = depts;
} @Override
public String toString() {
return "Company [msg=" + msg + ", depts=" + depts + "]";
}
}

另外Dept结构如下:

package com.Spring.Demo;

public class Dept {

    private Integer deptno;
private String name;
private boolean close; public boolean isClose() {
return close;
}
public void setClose(boolean close) {
this.close = close;
}
public Integer getDeptno() {
return deptno;
}
public void setDeptno(Integer deptno) {
this.deptno = deptno;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Dept [deptno=" + deptno + ", name=" + name + ", close=" + close + "]";
} }

配置如下:

    <bean id="dept1" class="com.Spring.Demo.Dept">
<property name="deptno" value="34"></property>
<property name="name" value="开发部门"></property>
<property name="close" value="no"></property>
</bean>
<bean id="dept2" class="com.Spring.Demo.Dept">
<property name="deptno" value="34"></property>
<property name="name" value="开发部门"></property>
<property name="close" value="no"></property>
</bean>
<bean id="dept3" class="com.Spring.Demo.Dept">
<property name="deptno" value="34"></property>
<property name="name" value="开发部门"></property>
<property name="close" value="no"></property>
</bean>
<bean id="dept4" class="com.Spring.Demo.Dept">
<property name="deptno" value="34"></property>
<property name="name" value="开发部门"></property>
<property name="close" value="no"></property>
</bean> <bean id="company" class="com.Spring.Demo.Company">
<property name="msg">
<props>
<prop key="mdln">mldn.com</prop>
<prop key="java">java.com</prop>
</props>
</property>
<property name="depts">
<list>
<ref bean="dept1"/>
<ref bean="dept2"/>
<ref bean="dept3"/>
<ref bean="dept4"/>
</list>
</property>
</bean>

由于集合里面的变量类型是自定义类类型,里面还有各种变量,这里用ref引用来设置。

所有可以在程序中的配置关系,现在完全可以通过配置文件横向替代了。

05-spring-bean注入的更多相关文章

  1. [spring]Bean注入——在XML中配置

    Bean注入的方式有两种: 一.在XML中配置 属性注入 构造函数注入 工厂方法注入 二.使用注解的方式注入@Autowired,@Resource,@Required 本文首先讲解在XML中配置的注 ...

  2. Spring bean注入方式

    版权声明:本文为博主原创文章,如需转载请标注转载地址. 博客地址:http://www.cnblogs.com/caoyc/p/5619525.html  Spring bean提供了3中注入方式:属 ...

  3. spring+cxf 开发webService(主要是记录遇到spring bean注入不进来的解决方法)

    这里不介绍原理,只是记录自己spring+cxf的开发过程和遇到的问题 场景:第三方公司需要调用我们的业务系统,以xml报文的形式传递数据,之后我们解析报文存储到我们数据库生成业务单据: WebSer ...

  4. Spring基础05——Spring依赖注入的三种方式

    Spring支持3种依赖注入的方式:属性注入.构造器注入.工厂 1.属性注入 属性注入即通过setter方法注入Bean的属性或依赖的对象.使用<property>元素,使用name属性指 ...

  5. spring bean 注入

    概念 http://developer.51cto.com/art/200610/33311.htm http://kb.cnblogs.com/page/45266/ ==https://www.c ...

  6. Spring Bean 注入 2 注解篇

    1. 自动装配注解 配置applicationContext.xml开启注解 <?xml version="1.0" encoding="UTF-8"?& ...

  7. Spring Bean 注入 1 - 构造方法注入,属性注入,自动装配

    1.代码结构图 xxx 2.bean代码 package com.xxx.bean; /** * Created with IntelliJ IDEA. * User: zhenwei.liu * D ...

  8. [spring]Bean注入——使用注解代替xml配置

    使用注解编程,主要是为了替代xml文件,使开发更加快速. 一.使用注解前提: <?xml version="1.0" encoding="UTF-8"?& ...

  9. Spring bean注入

    1.构造方法注入 1.bean类 public class User { private String name; private Integer age; private Cat cat; publ ...

  10. Spring JMX之一:使用JMX管理Spring Bean

    spring中关于jmx包括几个概念: MBeanExporter: 从字面上很容易理解, 用来将一些spring的bean作为MBean暴露给MBEanServer.MBeanServerFacto ...

随机推荐

  1. 【Kruskal】舒适的路线

    [codevs1001]舒适的路线 题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N(1<N≤500)个景点(编号为1,2,3,… ...

  2. [ARC062F]Painting Graphs with AtCoDeer

    题意:一个无向图,用$k$种不同的颜色给每条边染色,问能染出多少种不同的图,如果两张图能通过循环移位环边使得颜色相同,那么这两张图被认为是相同的 数学太差伤不起啊...补了一下Burnside定理的证 ...

  3. 【扫描线】Gym - 100781G - Goblin Garden Guards

    平面上有100000个哥布林和20000个圆,问你不在圆内的哥布林有多少个. 将每个圆从左到右切2r+1次,形成(2r+1)*2个端点,将上端点记作入点,下端点记作出点,再将这些点和那些哥布林一起排序 ...

  4. [LOJ500]ZQC的拼图

    题目大意: 给你一个m*m的格子,让你往里面放给定的直角三角形,直角顶点必须放在右上角且不能翻转,但是可以把所有给定的三角形放大一个整数倍k,问至少放大几倍能使格子的左下角和右上角连起来?(可以超出边 ...

  5. Perl中的数组&哈希应用

    哈希和数组是Perl中较为常用的结构,本文则重点讨论数组和哈希的一些基本用法,供广大喜爱Perl的同学们交流学习. 哈希 Perl中的哈希表类似于Python中的字典结构,由(键=>值)对构成, ...

  6. Wunder Fund Round 2016 (Div. 1 + Div. 2 combined) F. Double Knapsack 鸽巢原理 构造

    F. Double Knapsack 题目连接: http://www.codeforces.com/contest/618/problem/F Description You are given t ...

  7. 阿里云ECS使用SSH连接CentOS 6.9经常断线的问题解决:OperationTimedOut

    说明:不一定有效,可以试一下. 设置: vi /etc/ssh/sshd_config #添加或修改以下配置 ClientAliveInterval #每隔多少秒给SSH客户端发送一次信号 Clien ...

  8. 牛x的面试知识点

    已经凌晨2点多了,看来今天是失眠了,反正睡不着,写篇日记总结一下我的第一次社招面试经历吧.2015年12月1日办理了离职手续,离开了万通中心,也算是和我的第一个东家正式说了再见,其实还是很喜欢国贸的, ...

  9. spring boot 利用redisson实现redis的分布式锁

    原文:http://liaoke0123.iteye.com/blog/2375469 利用redis实现分布式锁,网上搜索的大部分是使用java jedis实现的. redis官方推荐的分布式锁实现 ...

  10. C++与Flash的交互

    研究Flash嵌入游戏中的可行性....... 渲染问题已解决 事件响应已解决 下面是C++与Flash AS的交互, 以MFC为例: 1. 新建一个MFC Dialog程序 2. 添加一个Flash ...