Bean的生命周期
我们研究一个东西的生命周期,就是为了更好的掌握它,从而更好的使用它。Spring中的bean也当如此。
我们知道,Spring中获取bean的两种方式:一是通过AppcationContext应用上下文接口获取,二是通过BeanFactory接口获取。二者不同之处在于前者在Spring容器启动加载xml文件时就会在内存当中实例化一个bean对象,后者只是在用户调用getbean()方法时才会在内存中实例化一个bean对象。后者的延迟加载bean对象,可以帮助节约内存,但是运行时负担会变重,因此BeanFactory方式主要用于移动端。
我们说Bean的生命周期,其实就是指的是bean对象的生命周期(只是在spring容器框架内讨论,不涉及底层对象的一些例如JVM的类加载或者GC等底层内容)。
一 ApplicationContext方式获取的bean对象的生命周期
①bean对象的实例化
这主要指的是启动spring容器加载xml文件时,spring会将我们的bean使用默认的无参的构造方法在内存中实例化,即这一步的“new”使用的是默认的无参构造方法,如果我们将默认的无参构造方法重写,那么会使用我们重写之后的方法;如果bean中没有无参构造方法的同时,却存在一个有参的构造方法,那么当spring在执行这一步时会报错。
总结来说就是,bean中必须存在一个重写的无参的构造方法(当然可以同时存在其他的构造方法),或者bean中不存在构造方法(现在spring会依赖于个默认的无参构造方法)。但是也有例外,那就是在自动装配的时候,可以指定一个带参的构造方法而不会导致报错。后面写自动装配的时候我