spring的核心技术---bean的生命周期加案例分析详细易懂

目录

一.spring管理JavaBean的初始化过程(生命周期)

Spring Bean的生命周期:

二.spring的JavaBean管理中单例模式及原型(多例)模式

        2.1 . 默认为单例,但是可以配置多例

        2.2.举例论证

                2.2.1 默认单例

               2.2.2 设置多例

               2.2.3单例与多例的初始化的时间点

三.总结


一.spring管理JavaBean的初始化过程(生命周期)

        在Spring框架中,Bean的生命周期是指从它被创建、初始化,到最终被销毁的整个过程。
        需要注意的是,Bean的销毁并不是由Java的垃圾回收器自动处理的,而是由Spring容器负责管理和销毁的。

下面一张图就是bean的整个生命周期图,它的一个初始化过程

Spring Bean的生命周期:

1)通过XML、Java annotation(注解)以及Java Configuration(配置类)
        等方式配置JavaBean,现在我用的是xml配置文件的方式
2)BeanDefinitionReader:解析Bean的定义。在Spring容器启动过程中,
        会将Bean解析成Spring内部的BeanDefinition结构;
        理解为:将spring.xml中的<bean>标签转换成BeanDefinition结构
        有点类似于XML解析
3)BeanDefinition:包含了很多属性和方法。例如:id、class(类名)、
        scope、ref(依赖的bean)等等。其实就是 将bean(例如<bean>)的定义信息
        存储到这个对应BeanDefinition相应的属性中,最终得到List<BeanDefinition>
4)BeanFactoryPostProcessor:是Spring容器功能的扩展接口。JavaBean初始化之前                先执行自己的业务
5)BeanFactory:bean工厂。它按照我们的要求生产我们需要的各种各样的bean。
6)Aware感知接口:在实际开发中,经常需要用到Spring容器本身的功能资源
        例如:BeanNameAware、ApplicationContextAware等等
        BeanDefinition 实现了 BeanNameAware、ApplicationContextAware
7)BeanPostProcessor:后置处理器。在Bean对象实例化和引入注入完毕后,
8)destory:销毁

二.spring的JavaBean管理中单例模式及原型(多例)模式

        2.1 . 默认为单例,但是可以配置多例

                单例的优点:节约内存;缺点:有变量污染;JavaBean是跟着spring上下文初始化的,容器生对象生,容器死对象死,因为单例只创建一次,所以最开始的时候就创建

                多例的优点:无变量污染;缺点:及其消耗内存;JavaBean是使用的时候才会创建,销毁跟着jvm走

举例说明:假如你有两个儿子,他们两个都想要一个玩具车。

          案例一,买一个,哥哥上午玩,弟弟下午玩,但是上午哥哥玩的时候如果玩具脏了,            刮花了,那么对于弟弟而言这个玩具已经不是原有车的状态,但是给我们省钱了=====》单例

        案例二:买两个,一人一个,这样就不存在污染,各玩各的,但是我们的钱包就扁了======》多例

        2.2.举例论证

                2.2.1 默认单例

        这个就是那辆车,bean对象,这里设了一个变量属性 num 来验证是不是单例,变量改变了

package com.zking.beanlife;

import java.util.List;

public class ParamAction {
	private int age;
	private String name;
	private List<String> hobby;
	private int num = 1;
	// private UserBiz userBiz = new UserBizImpl1();

	public ParamAction() {
		super();
	}

	public ParamAction(int age, String name, List<String> hobby) {
		super();
		this.age = age;
		this.name = name;
		this.hobby = hobby;
	}

	public void execute() {
		// userBiz.upload();
		// userBiz = new UserBizImpl2();
		System.out.println("this.num=" + this.num++);
		System.out.println(this.name);
		System.out.println(this.age);
		System.out.println(this.hobby);
	}
}

        再模拟方法数据,进行测试

package com.zking.beanlife;

public class InstanceFactory {
	public void init() {
		System.out.println("初始化方法");
	}

	public void destroy() {
		System.out.println("销毁方法");
	}

	public void service() {
		System.out.println("业务方法");
	}
}

        然后,进行xml文件配置,

         最后前台测试:是否默认为单例模式,并且变量被污染了,num值发生了变化,说明被污染了,默认为单例模式

         2.2.2 设置多例

        原来的代码不变,我们再xml配置文件中,选择多例

         前台测试结果,发现num值没有被污染

 2.2.3单例与多例的初始化的时间点

        当是多例的时候,不会初始化

         而当单例的时候,会初始化

 

三.总结

单例和多例的选择也需要考虑性能和资源消耗。单例可以节省资源,但可能存在线程安全问题;多例可以保证独立性,但会增加对象创建和销毁的开销。单例适合那些无状态或者线程安全的Bean,多例适合那些有状态的Bean或者需要每次请求都创建一个新实例的情况

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值