我已经意识到引用范围@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
的spring bean实例似乎只要引用相同的实例就会调用bean的新实例。
例如:
@Component
@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
class Item {
.....
}
@Component
@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
class A {
private Item item;
public void setItem(Item item) {
this.item = item;
}
public void method() {
item.doSomething();
}
}
@Component
@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
class B {
@Autowired
private A a;
@Autowired
private Item item;
void bMethod() {
a.setItem(item);
a.method();
}
}
A
中a.setItem(item);
的实例似乎与a.method();
中的实例不同,因此在范围为@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
的bean中使用访问器方法是不可能的。< / p>
这是预期的行为吗?我是否对@Scope(proxyMode = ScopedProxyMode.TARGET_CLASS, value = "prototype")
的使用情况缺乏了解?
答案 0 :(得分:2)
摆脱proxyMode
bean上的A
。使用proxyMode
TARGET_CLASS
,bean实际上是一个代理,它将任何方法调用委托给新实例。