Ответ 1
Это довольно просто. Идея состоит в том, что у вас есть объект-исполнитель, который bean, который передается в любой объект, который хочет запустить новую задачу (в новом потоке). Приятно, что вы можете изменить, какой тип исполнителя задач использовать, просто изменив конфигурацию Spring. В приведенном ниже примере я беру некоторый пример класса (ClassWithMethodToFire) и обертываю его в объект Runnable, чтобы сделать огонь; вы также можете реализовать Runnable в своем собственном классе, а затем в методе execute вы просто вызываете classWithMethodToFire.run()
.
Вот очень простой пример.
public class SomethingThatShouldHappenInAThread {
private TaskExecutor taskExecutor;
private ClassWithMethodToFire classWithMethodToFire;
public SomethingThatShouldHappenInAThread(TaskExecutor taskExecutor,
ClassWithMethodToFire classWithMethodToFire) {
this.taskExecutor = taskExecutor;
this.classWithMethodToFire = classWithMethodToFire;
}
public void fire(final SomeParameterClass parameter) {
taskExecutor.execute( new Runnable() {
public void run() {
classWithMethodToFire.doSomething( parameter );
}
});
}
}
И вот Spring beans:
<bean name="somethingThatShouldHappenInAThread" class="package.name.SomethingThatShouldHappenInAThread">
<constructor-arg type="org.springframework.core.task.TaskExecutor" ref="taskExecutor" />
<constructor-arg type="package.name.ClassWithMethodToFire" ref="classWithMethodToFireBean"/>
</bean>
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<property name="corePoolSize" value="5" />
<property name="maxPoolSize" value="10" />
<property name="queueCapacity" value="25" />
</bean>