3spring:生命周期,属性赋值,自动装配
有不懂的可以参考之前的文章!
https://www.cnblogs.com/Mrchengs/p/10109053.html
1.Bean的生命周期
public class Chirld {
public Chirld() {
System.out.println("创建Child实例....");
}
public void init(){
System.out.println("初始化方法.....");
}
public void destroy(){
System.out.println("销毁方法....");
}
}
@Configuration
public class TheLifeOfInitAnfDestroy {
@Bean(initMethod="init",destroyMethod="destroy")
public Chirld car(){
return new Chirld();
}
}
@Test
public void test4(){
AnnotationConfigApplicationContext app = new AnnotationConfigApplicationContext(TheLifeOfInitAnfDestroy.class); System.out.println("容器创建完成");
//关闭
app.close();
}
创建Child实例....
初始化方法.....
容器创建完成
十一月 , :: 上午 org.springframework.context.annotation.AnnotationConfigApplicationContext doClose
信息: Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@512ddf17: startup date [Fri Nov :: CST ]; root of context hierarchy
销毁方法....
在容器关闭的时候进行销毁
2.接口方法
public interface InitializingBean {
void afterPropertiesSet() throws Exception;
}
public interface DisposableBean {
void destroy() throws Exception;
}
@Component
public class Chirld2 implements InitializingBean,DisposableBean { public Chirld2() {
System.out.println("创建Child2实例....");
}
public void afterPropertiesSet() throws Exception {
System.out.println("init....."); }
public void destroy() throws Exception {
System.out.println("destroy....");
}
}
@Configuration
@ComponentScan("coom.MrChengs.bean")
public class TheLifeOfInitAnfDestroy { }
@Test
public void test4(){
AnnotationConfigApplicationContext app = new AnnotationConfigApplicationContext(TheLifeOfInitAnfDestroy.class); System.out.println("容器创建完成");
//关闭
app.close();
}
创建Child2实例....
init.....
容器创建完成
十一月 , :: 上午 org.springframework.context.annotation.AnnotationConfigApplicationContext doClose
信息: Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@512ddf17:
startup date [Fri Nov :: CST ]; root of context hierarchy
destroy....
//代码.....
4.BeanPostProcessor接口:bean的后置处理器
@Configuration
@ComponentScan("coom.MrChengs.bean")
public class TheLifeOfInitAnfDestroy {
}
@Test
public void test4(){
AnnotationConfigApplicationContext app = new AnnotationConfigApplicationContext(TheLifeOfInitAnfDestroy.class);
System.out.println("容器创建完成");
//关闭
app.close();
}
post init.....
aftet init ....
post init.....
aftet init ....
post init.....
aftet init ....
创建Child2实例....
post init.....
init.....
aftet init ....
容器创建完成
十一月 , :: 上午 org.springframework.context.annotation.AnnotationConfigApplicationContext doClose
信息: Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@512ddf17: startup date [Fri Nov :: CST ]; root of context hierarchy
destroy....
2.属性赋值:
person.properties
person.school=MrChengs
public class Person {
@Value("MrChengs")
private String name;
@Value("#{20-12}")
private int age;
@Value("${person.school}")
private String school;
...
}
@Configuration
//引入资源
@PropertySource(value={"classpath:/person.properties"})
public class ValueConfig {
@Bean
public Person person(){
return new Person();
}
}
@Test
public void test5(){
AnnotationConfigApplicationContext app = new AnnotationConfigApplicationContext(ValueConfig.class); String [] names = app.getBeanDefinitionNames();
for(String name : names){
System.out.println(name);
}
Person person = app.getBean(Person.class);
System.out.println(person); }
valueConfig
person
Person [name=MrChengs, age=8, school=MrChengs]
public @interface PropertySource {
String name() default "";
String[] value();
boolean ignoreResourceNotFound() default false;
String encoding() default "";
Class<? extends PropertySourceFactory> factory() default PropertySourceFactory.class;
}
自动装配:
@Autowired
applicationContext.getBean("customerDao")...
@Autowired
private CustomerDao customerDao;
默认按照方法名去id中查找
@Qualifier("customerDao")
@Autowired
private CustomerDao customerDao2;
@Qualifier("customerDao")
@Autowired(required=false)
private CustomerDao customerDao2;
6.@Primary:让spring进行装配的时候,默认使用首选的bean
@Autowired(required=false)
private CustomerDao customerDao; @Primary
@Bean("customerDao2")
public CustomerDao customer(){
...
}
@Repository
public class CustomerDao {
}
@Service
public class CustomerService {
@Autowired
private CustomerDao customerDao; public void print(){
System.out.println("---->"+customerDao);
}
}
@Configuration
@ComponentScan({"coom.MrChengs.config.service","coom.MrChengs.config.dao"})
public class AutowiredConfig {
@Bean("customerDao2")
public CustomerDao customer(){
return new CustomerDao("customer2");
} }
@Test
public void test6(){
AnnotationConfigApplicationContext app = new
AnnotationConfigApplicationContext(coom.MrChengs.config.AutowiredConfig.class); String [] names = app.getBeanDefinitionNames();
for(String name : names){
System.out.println(name);
}
CustomerService cus = app.getBean(CustomerService.class);
cus.print();
//System.out.println(cus);
}
autowiredConfig
customerService 此时容器中有两个相同类型的bean
customerDao
customerDao2 此时注入的类型是:
---->CustomerDao [name=null]
@Resource
private CustomerDao customerDao;
可以修改器默认装配的名称
@Resource(name="customerDao2")
private CustomerDao customerDao;
不可以支持@Primary功能和request=false的功能
<!-- https://mvnrepository.com/artifact/javax.inject/javax.inject -->
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
@Inject
private CustomerDao customerDao;
@Autowire
@Target({ElementType.CONSTRUCTOR, ElementType.METHOD,
ElementType.PARAMETER, ElementType.FIELD, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Autowired {
可以标注的位置有构造器,方法,属性
方法上
@Component
public class Person {
...
}
@Component
public class Students {
...
@Autowired
public void setPerson(Person person) {
this.person = person;
}
..
}
AnnotationConfigApplicationContext app = new
AnnotationConfigApplicationContext(coom.MrChengs.config.AutowiredConfig.class); Students s = app.getBean(Students.class); System.out.println(s);
Person p = app.getBean(Person.class);
System.out.println(p);
Students [person=Person [name=MrChengs, age=, school=${person.school}], name=null]
Person [name=MrChengs, age=, school=${person.school}]
@Autowired
public Students(Person person, String name) {
super();
this.person = person;
this.name = name;
System.out.println("Students.....");
}
3spring:生命周期,属性赋值,自动装配的更多相关文章
- Spring笔记(2) - 生命周期/属性赋值/自动装配及部分源码解析
一.生命周期 @Bean自定义初始化和销毁方法 //====xml方式: init-method和destroy-method==== <bean id="person" c ...
- Spring Bean 注入 1 - 构造方法注入,属性注入,自动装配
1.代码结构图 xxx 2.bean代码 package com.xxx.bean; /** * Created with IntelliJ IDEA. * User: zhenwei.liu * D ...
- 从EFCore上下文的使用到深入剖析DI的生命周期最后实现自动属性注入
故事背景 最近在把自己的一个老项目从Framework迁移到.Net Core 3.0,数据访问这块选择的是EFCore+Mysql.使用EF的话不可避免要和DbContext打交道,在Core中的常 ...
- Spring 框架基础(02):Bean的生命周期,作用域,装配总结
本文源码:GitHub·点这里 || GitEE·点这里 一.装配方式 Bean的概念:Spring框架管理的应用程序中,由Spring容器负责创建,装配,设置属性,进而管理整个生命周期的对象,称为B ...
- Spring - bean的autowire属性(自动装配)
当我们要往一个bean的某个属性里注入另外一个bean,我们会使用<property> + <ref/>标签的形式.但是对于大型项目,假设有一个bean A被多个bean引用注 ...
- spring4笔记----spring生命周期属性
init-method : 指定bean的初始化方法-spring容器会在bean的依赖关系注入完成后调用该方法 destroy-method :指定bean销毁之前的方法-spring容器将会在销毁 ...
- 浅尝Spring注解开发_自定义注册组件、属性赋值、自动装配
Spring注解开发 浅尝Spring注解开发,基于Spring 4.3.12 包含自定义扫描组件.自定义导入组件.手动注册组件.自动注入方法和参数.使用Spring容器底层组件等 配置 @Confi ...
- bean的autowire属性及其生命周期
一:sutowire属性 1.no:默认值,禁用自动装配: 2.byName:根据属性名称自动装配: 3.byType:根据属性类型自动装配: 4.constructor:通过构造方法自动装配,不推荐 ...
- [原创]java WEB学习笔记99:Spring学习---Spring Bean配置:自动装配,配置bean之间的关系(继承/依赖),bean的作用域(singleton,prototype,web环境作用域),使用外部属性文件
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
随机推荐
- input:checkbox 是否被选中?
<input type="checkbox" id="checkbox1"> <script> $(function(){ $(&quo ...
- moment常用操作
1.返回当前日期截止时的时间戳: post.createtime = moment().unix(); let stime = moment(moment.unix(moment().unix()). ...
- JavaScript事件流--事件冒泡、目标与事件捕获
1.事件冒泡 微软提出了名为事件冒泡的事件流.事件冒泡可以形象地比喻为把一颗石头投入水中,泡泡会一直从水底冒出水面.也就是说,事件会从最内层的元素开始发生,一直向上传播,直到document对象. 因 ...
- node.js之内存机制特性
Node.JS的V8引擎具有垃圾回收机制与内存限制的特性,V8的内存限制:64位系统约为1.4GB.32位系统约为0.7GB:V8采用基于分代式垃圾回收机制,堆内存结构分为新生代和老生代,新生代达到一 ...
- 《深入理解Java内存模型》读书总结(转-总结很好)
概要 文章是<深入理解Java内容模型>读书笔记,该书总共包括了3部分的知识. 第1部分,基本概念 包括“并发.同步.主内存.本地内存.重排序.内存屏障.happens before规则. ...
- php FastCGI 进程意外退出 错误解决方法
服务器windows2008,php5.5 / php5.6,需要安装VC++运行库. 到Microsoft网站下载“Microsoft Visual C++ 2012 Redistributable ...
- 洛谷P3952 时间复杂度(模拟)
题意 题目链接 Sol 咕了一年的题解..就是个模拟吧 考场上写的递归也是醉了... 感觉一年自己进步了不少啊..面向数据编程的能力提高了不少 #include<bits/stdc++.h> ...
- Linux下mongodb
Linux下mongodb安装: 新建mongodb文件夹 下载安装包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3. ...
- Java中线程的实现
在Java中要想实现多线程代码有两种方法,一种是继承 Thread 类,另一种就是实现 Runnable 接口 一.继承 Thread 类 Thread 类是在 java.lang 包中定义的,一个类 ...
- PeekMessage&GetMessage
原文:http://www.cnblogs.com/faceang/archive/2010/05/25/1743757.html PeekMessage与GetMessage的对比相同点:PeekM ...