我在Spring 3中使用查找方法注入将原型bean注入到单个bean中,如Spring docs here中所述。在我的原型bean里面,我对applicationContext.xml中声明的另一个bean有一个@Autowired
依赖。查找方法注入似乎正常工作,因为我的原型bean被注入到我的单例bean中,但是,原型的依赖性根本没有被注入。当通过查找方法返回原型时,可以以正常方式将依赖项注入原型bean吗?如果没有,那么首选方法是什么?
编辑:bean定义如下:
<bean id="jobRouter" class="com.ccn.JobRouter">
<lookup-method name="createJobConsumer" bean="jobConsumer"/>
</bean>
<bean id="jobConsumer" class="com.ccn.JobConsumer" scope="prototype"/>
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<property name="corePoolSize" value="5" />
<property name="maxPoolSize" value="100" />
<property name="WaitForTasksToCompleteOnShutdown" value="true" />
</bean>
JobRouter
public abstract class JobRouter {
private LinkedHashMap<String, JobConsumer> jobRoutingMap = new LinkedHashMap<String, JobConsumer>();
public void add(Job Job) {
if(!jobRoutingMap.containsKey(job.getObjectKey())){
jobRoutingMap.put(job.getObjectKey(), createJobConsumer());
}
//Hand off job to consumer
JobConsumer jobConsumer = jobRoutingMap.get(job.getObjectKey());
jobConsumer.add(job);
}
protected abstract JobConsumer createJobConsumer();
}
JobConsumer
public class JobConsumer {
@Autowired private TaskExecutor taskExecutor;
private LinkedBlockingQueue<Job> jobQueue = new LinkedBlockingQueue<Job>();
public JobConsumer() {
taskExecutor.execute(new JobQueueMonitor());
}
public boolean add(Job job) {
if(!jobQueue.contains(job)){
return jobQueue.add(job);
}
return true;
}
private class JobQueueMonitor implements Runnable{
@Override
public void run() {
...
}
}
}
答案 0 :(得分:0)
我发现原型bean中的依赖实际上是正确注入的。问题是我在注入依赖项之前尝试访问构造函数内部的依赖项(参见上面代码中的JobConsumer构造函数),它显然是null。我将代码从JobConsumer构造函数移动到@PostConstruct
带注释的方法中,并按预期工作。