Bean装配

Spring提供了3种装配机制:

1)隐式的Bean发现机制和自动装配

2)在Java中进行显示装配

3)在XML中进行显示装配

一)自动化装配

1.指定某类为组件类:

@Component
public class Dog {
private String name = "Jerry";
//省略getter/setter
}
public interface Person {
void introduce();
}
//表明该类会作为组件,告知Spring为该类创建bean
//该组件的默认id为:student
@Component
//@Component("aStudent") 为该bean指定id:aStudent
//当然也可以使用Java依赖注入规范:
//@Named("aStudent")
public class Student implements Person{
@Autowired
private Dog dog;
private String name = "Tom";
private int age = 6;
private String school = "Happy School"; public Student() {
}
public Student(String name, int age, String school) {
this.name = name;
this.age = age;
this.school = school;
} public void introduce() {
System.out.println("My name is " + name + ", I'm " + age +
" years old. I'm from " + school + " !");
System.out.println("I have dog named " + dog.getName());
}
//省略getter/setter
}

2.创建配置类启用组件扫描

1)通过Java配置:

@Configuration
//@ComponentScan 启用组件扫描功能,此时是扫描该类所在包下的所有组件类
@ComponentScan("beans") //设置要扫描的包
//@ComponentScan(basePackages = "beans") 同上
//@ComponentScan(basePackages = {"a", "b", "c"}) 扫描多个包
//@ComponentScan(basePackageClasses = {a.class, b.class, c.class}) 扫描class所在包
public class PersonConfig {
}

2)通过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:Context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd"> <Context:component-scan base-package="beans"/>
</beans>

3.测试: 

//该注解创建了Spring应用上下文
@RunWith(SpringJUnit4ClassRunner.class)
//加载配置
@ContextConfiguration(classes = PersonConfig.class)
public class PersonTest {
//@Autowired(required = false) 设置为false没有匹配bean时不抛出异常
@Autowired //当然该注解也可用于方法
Person student;
@Test
public void say() {
student.introduce();
//My name is Tom, I'm 6 years old. I'm from Happy School !
//I have dog named Jerry
}
}

二)通过Java装配

public class Father implements Person{
private Student student;
public Father(Student student) {
this.student = student;
}
public void introduce() {
System.out.println("I'm " + student.getName() + "'s father.");
}
}
@Configuration
public class PersonConfig {
@Bean
public Dog dog() {
Dog dog = new Dog();
dog.setName("Flex");
return dog;
} @Bean //告诉Spring返回的对象注册为Spring应用上下文的bean
//@Bean(name = "aName") 修改默认名字
public Student getStudent(){
Student student = new Student("Jimmy", 22, "Sad School");
student.setDog(dog());
return student;
} //此处注解会拦截getStudent()方法,传入Spring创建的单例
@Bean
public Father getFather() {
return new Father((Student) getStudent());
} //通过这种方法引用其他bean是最佳方式
//因为它不要求将person声明到同一配置文件中
public Person father(Person person) {
return new Father((Student) person);
}
}
@Autowired
Student student;
@Autowired
Father father;
@Test
public void say() {
student.introduce();
father.introduce();
/*My name is Jimmy, I'm 22 years old. I'm from Sad School !
I have dog named Flex
I'm Jimmy's father.*/
}

三)通过XML装配

PersonTest-contxt.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean class="beans.Book" id="book1">
<property name="bookName" value="YellowBook"/>
</bean>
<bean class="beans.Book" id="book2">
<property name="bookName" value="GreenBook"/>
</bean>
<bean class="beans.Dog" id="dog">
<!--属性注入必须提供相应的属性set方法-->
<property name="name" value="小白"/>
</bean>
<bean class="beans.Student" id="student">
<property name="dog" ref="dog"/>
<constructor-arg value="Harry"/>
<constructor-arg value="28" />
<constructor-arg value="Killer School"/>
<property name="books">
<list>
<ref bean="book1"/>
<ref bean="book2"/>
</list>
</property>
</bean>
<bean class="beans.Father" id="father">
<constructor-arg ref="student" />
</bean>
</beans>
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration // @ContextConfiguration(locations = { "classpath*:/spring1.xml", "classpath*:/spring2.xml" })
public class PersonTest {
@Autowired
Student student;
@Autowired
Father father;
@Test
public void say() {
student.introduce();
father.introduce();
/* My name is Harry, I'm 28 years old. I'm from Killer School !
I have dog named 小白
I have 2 books.
I'm Harry's father.*/ }
}

四)导入混合配置

1.在JavaConfig导入其他JavaConfig

@Import(AnotherConfig.class)
@Import({One.class, Tow.class})

2.在JavaConfig中导入xml配置

@ImportResource("classpath: one.xml")

3.在xml中导入其他xml

<import resoune="one.xml">

注意并没有XML能导入JavaConfig

Spring使用笔记(二)Bean装配的更多相关文章

  1. Spring学习笔记(二)之装配Bean

    一,介绍Bean的装配机制 在Spring中,容器负责对象的创建并通过DI来协调对象之间的关系.但是我们要告诉Spring创建哪些Bean并且如何将其装配在一起.,装配wiring就是DI依赖注入的本 ...

  2. Spring系列(二) Bean装配

    创建应用对象之间协作关系的行为称为装配(wiring), 这也是DI的本质. Spring中装配Bean的方式 Spring提供了三种装配Bean的方式. 隐式的Bean发现机制和自动装配 Java ...

  3. Spring初学笔记(二):Bean的注入

    关于Bean的注入 在上一篇中,已经说到虽然注入确实可以降低类与类之间的耦合,但并没有解决调用者必须知道类的创建方法的问题,也可以说是没有实现调用者与类实现的解耦,我们也提到,为了实现两者的解耦,可以 ...

  4. Spring学习系列(二) 自动化装配Bean

    一.Spring装配-自动化装配 @Component和@ComponentScan 通过spring注解(@Component)来表明该类会作为组件类,并告知Spring要为这类创建bean,不过组 ...

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

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

  6. Spring学习笔记(三)之装配Bean

    除了组件扫描与自动装配之外还有基于Java代码的装配与基于XML的装配. 有一些场景是我们不能用自动装配的,比如我们要给第三方库中的组件装配到我们的应用中,这时自动装配无效,因为自动装配只能扫描本应用 ...

  7. spring深入学习(二)-----bean的生命周期、IOC容器bean装配

    bean的生命周期 1.实例化Bean对于BeanFactory容器,当客户向容器请求一个尚未初始化的bean时,或初始化bean的时候需要注入另一个尚未初始化的依赖时,容器就会调用createBea ...

  8. 【spring学习笔记二】Bean

    ### bean的三种实例化方式: 1.构造 2.静态工厂 3.实例工厂 其中,工厂就是工厂的概念,工厂函数factor-method会返回她生产出来的产品类. 而构造初始化也可以选择初始化方式和销毁 ...

  9. spring学习笔记二 注解及AOP

    本节需要导入spring-aop包 注解 使用注解的目的是为了代替配置,在使用注解时,省略键时,则是为value赋值. 扫描某个包下的所有类中的注解 <?xml version="1. ...

  10. Spring Boot笔记二:快速创建以及yml文件自动注入

    上个笔记写了如何自己去创建Spring boot,以及如何去打jar包,其实,还是有些麻烦的,我们还自己新建了几个文件夹不是. Idea可以让我们快速的去创建Spring boot应用,来看 一.快速 ...

随机推荐

  1. 20165314 学习基础和C语言基础调查

    技能学习心得 你有什么技能比大多人(超过90%以上)更好?针对这个技能的获取你有什么成功的经验?与老师博客中的学习经验有什么共通之处? 从小我的父母就逼着我学习很多技能,比如钢琴,围棋,书法等,不过很 ...

  2. Plain Old Data (POD) (转)

    定义 POD类型包括下述C++类型,以及其cv-qualified的类型,还有以其为基类型的数组类型: 标量类型(scalar type) POD类类型(POD class type) 标量类型 术语 ...

  3. 剑指offer之二叉树

    二叉树前序,中序,后序遍历思想 前序遍历:ABDCEFGH 中序遍历:BDAFEHGC 后序遍历:DBFHGECA 科普 队列(queue)是一种常用的数据结构,可以将队列看做是一种特殊的线性表,该结 ...

  4. mysql 5.7 安装

    linux(CentOS6.7) 环境Mysql 5.7.17安装教程分享给大家,供大家参考,具体内容如下: 1系统约定 安装文件下载目录:/data/software Mysql目录安装位置:/us ...

  5. TodoMVC:帮助你选择一个MV*框架

    开发者现在有很多的MV*框架选择来组织开发web应用程序.Backbone. Ember.AngularJS.Spine… 新的稳定解决方案列表持续增长,但你如何决定在海量的框架中选择哪个使用? 为了 ...

  6. snmp v3的安全配置 snmp认证与加密配置(53)

    http://www.ttlsa.com/zabbix/snmp-v3-configuration/

  7. DBEntityEntry类

    DBEntityEntry是一个重要的类,可用于检索有关实体的各种信息.您可以使用DBContext的Entry方法获取特定实体的DBEntityEntry实例. DBEntityEntry允许您访问 ...

  8. 【转】Crosswalk入门

    原文:https://www.mobibrw.com/2015/1934 Crosswalk是一款开源的web引擎.目前Crosswalk正式支持的移动操作系统包括Android和Tizen,在And ...

  9. 标准I/O的缓冲

    标准I/O实现了三种类型的用户缓冲,并为开发者提供了接口,可以控制缓冲区类型和大小. 无缓冲(Unbuffered) 不执行用户缓冲.数据直接提交给内核.因为这种无缓冲模式不支持用户缓冲(用户缓冲一般 ...

  10. fillder--客户端指定访问IP段