* spring容器中的bean创建
* 三种方案
* 利用默认的构造函数
* 利用静态工厂方法
* 利用实例工厂方法
* 创建对象的时机
* 默认情况下,在spring启动的时候,创建纳入spring容器中所有的bean
在spring容器启动的时候,可以检查错误
但是如果bean的属性中有数据,会过早的加载到内存中,所以如果bean中有数据
应该把数据的对象的声明放在方法中
* 如果在spring的配置文件中,有lazy-init为true,则context.getBean("beanId")时
才要创建对象
缺点:在spring容器启动的时候,是检验不出错误的
* 对象的作用域
* 在配置文件中,scope为
"singleton"
* 默认值
* spring产生的bean只有一个实例
* 处于单例模式的bean的创建、初始化、销毁都是受spring容器管理的
* 在容器关闭的时候执行销毁工作
"prototype"
* 多例
* spring容器负责该bean的创建、初始化,但是销毁工作程序员做
* 无论该bean的lazy-init为什么值,都在context.getBean时创建对象
* 三种方案
* 利用默认的构造函数
* 利用静态工厂方法
* 利用实例工厂方法
* 创建对象的时机
* 默认情况下,在spring启动的时候,创建纳入spring容器中所有的bean
在spring容器启动的时候,可以检查错误
但是如果bean的属性中有数据,会过早的加载到内存中,所以如果bean中有数据
应该把数据的对象的声明放在方法中
* 如果在spring的配置文件中,有lazy-init为true,则context.getBean("beanId")时
才要创建对象
缺点:在spring容器启动的时候,是检验不出错误的
* 对象的作用域
* 在配置文件中,scope为
"singleton"
* 默认值
* spring产生的bean只有一个实例
* 处于单例模式的bean的创建、初始化、销毁都是受spring容器管理的
* 在容器关闭的时候执行销毁工作
"prototype"
* 多例
* spring容器负责该bean的创建、初始化,但是销毁工作程序员做
* 无论该bean的lazy-init为什么值,都在context.getBean时创建对象
* 如果该bean中有资源对象,手动关闭
* init和destroy方法
init在构造器执行完毕之后执行
destroy方法在spring关闭的时候执行