在原型bean中注入依赖项

时间:2013-11-20 15:40:06

标签: java spring dependency-injection

我在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() {
         ...
      }
   }
}

1 个答案:

答案 0 :(得分:0)

我发现原型bean中的依赖实际上是正确注入的。问题是我在注入依赖项之前尝试访问构造函数内部的依赖项(参见上面代码中的JobConsumer构造函数),它显然是null。我将代码从JobConsumer构造函数移动到@PostConstruct带注释的方法中,并按预期工作。