spring4 - 4 -SpEL - 生命周期方法 - 工厂方法

································spring表达式语言SpEL······························

Spring 表达式语言(简称SpEL):是一个支持运行时查询和操作对象图的强大的表达式语言。
语法类似于 EL:SpEL 使用 #{…} 作为定界符,所有在大框号中的字符都将被认为是 SpEL
SpEL 为 bean 的属性进行动态赋值提供了便利
通过 SpEL 可以实现:

	通过 bean 的 id 对 bean 进行引用
	调用方法以及引用对象中的属性
	计算表达式的值
	正则表达式的匹配


字面量的表示:
	整数:<property name="count" value="#{5}"/>
	小数:<property name="frequency" value="#{89.7}"/>
	科学计数法:<property name="capacity" value="#{1e4}"/>
	String可以使用单引号或者双引号作为字符串的定界符号:<property name=“name” value="#{'Chuck'}"/> 
	或 <property name='name' value='#		{"Chuck"}'/>
	Boolean:<property name="enabled" value="#{false}"/>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

····························IOC容器中bean的生命周期方法·························

Spring IOC 容器可以管理 Bean 的生命周期, Spring 允许在 Bean 生命周期的特定点执行定制的任务. 
Spring IOC 容器对 Bean 的生命周期进行管理的过程:

通过构造器或工厂方法创建 Bean 实例
为 Bean 的属性设置值和对其他 Bean 的引用
调用 Bean 的初始化方法
Bean 可以使用了
当容器关闭时, 调用 Bean 的销毁方法
在 Bean 的声明里设置 init-method 和 destroy-method 属性, 为 Bean 指定初始化和销毁方法.

Bean 后置处理器允许在调用初始化方法前后对 Bean 进行额外的处理.
Bean 后置处理器对 IOC 容器里的所有 Bean 实例逐一处理, 而非单一实例. 其典型应用是: 检查 Bean 属性的正确性或根据特定的标准更改 Bean 的属性.
对Bean 后置处理器而言, 需要实现接口. 在初始化方法被调用前后, Spring 将把每个 Bean 实例分别传递给上述接口的以下两个方法:

在这里插入图片描述

Spring IOC 容器对 Bean 的生命周期进行管理的过程:

通过构造器或工厂方法创建 Bean 实例
为 Bean 的属性设置值和对其他 Bean 的引用
将 Bean 实例传递给 Bean 后置处理器的 postProcessBeforeInitialization 方法
调用 Bean 的初始化方法
将 Bean 实例传递给 Bean 后置处理器的 postProcessAfterInitialization方法
Bean 可以使用了
当容器关闭时, 调用 Bean 的销毁方法

···········································code·············································

················(xml)················
	<!-- 指定 car的初始化及销毁方法  -->
	<bean id = "car" class = "bean.cycle.car" init-method = "init" destroy-method="destory">
		<property name="brand" value = "audi"></property>
	</bean>
	<!-- 实现beanpostprocessor 接口,并具体提供
		postProcessBeforeInitialization(Object arg0, String arg1) init-method之前被调用
		postProcessAfterInitialization(Object arg0, String arg1) init-method之后被调用
		的实现
		
		bean:bean实例本身
		beanname: ioc容器中配置bean的名字
		返回值:是实际上返回给用户的bean,可以在以上两个方法中修改返回的bean
	-->
	<!-- 配置bean的后置处理器 -->
	<!-- 不需要配置id,IOC容器自动识别是一个beanpostprocessor -->
	<bean class = "bean.cycle.beanPostProcessor"></bean>
</beans>


·········(beanpostprocessor.java)··········································


package bean.cycle;

import org.springframework.beans.BeansException;
import org.springframework.beans.factory.config.BeanPostProcessor;

public class beanPostProcessor implements BeanPostProcessor {

	@Override
	public Object postProcessAfterInitialization(Object arg0, String arg1) throws BeansException {
		// TODO Auto-generated method stub
		System.out.println("postProcessAfterInitialization" + "," + arg0 + "," + arg1);
		return arg0;
	}
	//可以在后置处理器中对象或属性
	
	@Override
	public Object postProcessBeforeInitialization(Object arg0, String arg1) throws BeansException {
		// TODO Auto-generated method stub
		System.out.println("postProcessBeforeInitialization" + "," + arg0 + "," + arg1);
		
		//对所有的bean进行处理,修改时要进行过滤
		if("car".equals(arg1)) {
			//...
		}
		car car  = new car();
		car.setBrand("ford");
		return car;
	}

}

································工厂方法创建bean····································

(通过调用静态工厂方法创建bean)································

	调用静态工厂方法创建 Bean是将对象创建的过程封装到静态方法中. 当客户端需要对象时, 只需要简单地调用静态方法,
	 而不同关心创建对象的细节.
	 
	要声明通过静态方法创建的 Bean, 需要在 Bean 的 class 属性里指定拥有该工厂的方法的类, 同时在 factory-method 属性里
	指定工厂方法的名称. 最	后, 使用 <constrctor-arg> 元素为该方法传递方法参数.

(通过实例工厂方法创建bean)·····································

	实例工厂方法: 将对象的创建过程封装到另外一个对象实例的方法里. 当客户端需要请求对象时, 只需要简单的调用该实例方法而不需要关心
	对象的创建细节.
	
	要声明通过实例工厂方法创建的 Bean
	在 bean 的 factory-bean 属性里指定拥有该工厂方法的 Bean
	在 factory-method 属性里指定该工厂方法的名称
	使用 construtor-arg 元素为工厂方法传递方法参数


···········································code·············································

(StaticFactory.java)··································

package factory;
import java.util.HashMap;
import java.util.Map;

public class StaticFactory {
//静态工厂方法:直接调用某一个类的静态方法就可以返回bean的实例
	private static Map<String, car> cars = new HashMap<String, car>();
	static {
		cars.put("audi", new car("12", "12"));
		cars.put("ford", new car("123", "212"));
		cars.put("lanbo", new car("112", "121"));
	}
	//静态工厂方法 
	public static car getcar(String name) {
		return cars.get(name);
	}
}



(instanceFactory.java)··································

package factory;
import java.util.HashMap;
import java.util.Map;

public class InstanceFactory {
	private Map<String, car> cars = null;
	//实例工厂方法 即需要创建工厂本身,再调用工厂实例方法来返回bean实例
	public InstanceFactory() {
		cars = new HashMap<String, car>();
		cars.put("audi", new car("12", "123"));
		cars.put("fork", new car("12", "123"));
		cars.put("fasdf", new car("12", "123"));
	}
	public car getcar(String brand) {
		return cars.get(brand);
	}
}


(beanfactory.xml)
	
	<!-- 通过静态工厂方法来配置bean,不是配置静态工厂方法实例,而是配置bean实例 -->
	<!-- class属性 : 指向 静态工厂方法的全类名
		 factory-method:指向静态工厂方法名字
		 constructor-arg:如果工厂方法需要传入参数,则使用constructor-arg传入
	-->
	<bean id = "car1" class = "factory.StaticFactory" factory-method = "getcar">
		<constructor-arg value = "audi"></constructor-arg>
	</bean>
	
	<!-- 配置工厂的实例 -->
	<bean id = "carfactory" class = "factory.InstanceFactory"></bean>
	<bean id = "car2" factory-bean = "carfactory" factory-method = "getcar">
		<constructor-arg value = "fork"></constructor-arg>
	</bean>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值