属性lookup-method的解析过程
parseLookupOverrideSubElements(ele, bd.getMethodOverrides());
引用
public void parseLookupOverrideSubElements(Element beanEle, MethodOverrides overrides) {
NodeList nl = beanEle.getChildNodes();
for (int i = 0; i < nl.getLength(); i++) {
Node node = nl.item(i);
if (isCandidateElement(node) && nodeNameEquals(node, LOOKUP_METHOD_ELEMENT)) {
Element ele = (Element) node;
String methodName = ele.getAttribute(NAME_ATTRIBUTE);
String beanRef = ele.getAttribute(BEAN_ELEMENT);
LookupOverride override = new LookupOverride(methodName, beanRef);
override.setSource(extractSource(ele));
overrides.addOverride(override);
}
}
}
lookup-method是一种method injection的。这个属性可以使Spring克服当一个bean依赖其他不同生命周期的bean的情况,比如当一个单例bean依赖一个非单例对象的时候
假设需要在一个单例bean注入一个原型bean
虽然被注入的是一个原型bean,但是由于单例的bean只会初始化一次,所以这个原型bean实际上可以看成是一个“单例bean”
这时使用 <lookup-method bean="原型bean的id" name="方法名称"/>属性即可解决上述问题
属性replaced-method:
<replaced-method name="被替换的方法" replacer="替换类,该类必须实现MethodReplacer接口">
<arg-type></arg-type>//如果这个被替换的方法被重载了,那么必须写arg-type
</replaced-method>
注意,在这里<arg-type></arg-type>只表示一个参数,若想表示某一个类型的参数,必须写成
<arg-type match="String"></arg-type>,这样才会被解析成一个为String类型的参数,而
<arg-type>String</arg-type>这样只会被解析成拦截只有一个参数的某方法