1.应用中创建
ExecutorService executorService=Executors.newFixedThreadPool(nThreads);
nThreads为线程池中可以创建的最大数量的线程。
2.通过Spring的配置文件创建
<bean id="executorService" class="java.util.concurrent.Executors" factory-method="newFixedThreadPool">
<constructor-arg value="5"></constructor-arg>
</bean>
1.创建
ExecutorService executorService = Executors.newFixedThreadPool(threads);
ExecutorService中的 Future<?> submit(Runnable task);会将Runnable方法封装成一个Future对象,只是返回的对象为null,
2.对于<T> Future<T> submit(Callable<T> task);调用返回的Future对象,如果调用future.get(),那么ExecutorService的操作会一直阻塞在那里,直到get()返回值。
3.shutdown()方法会使的ExecutorService 不再接收新的task,但是对正在运行的任何没有任何影响。
4.shutdownNow()方法会给ExecutorService 中的线程执行interrupt()方法,如果task运行的过程中检验这个这个标记,通过Thread.currentThread().isInterrupted()或者Thread.interrupted()方法来检测是否有打断标记,interrupted()方法执行后,打断标记会被清除。
ExecutorService executorService=Executors.newFixedThreadPool(nThreads);
nThreads为线程池中可以创建的最大数量的线程。
2.通过Spring的配置文件创建
<bean id="executorService" class="java.util.concurrent.Executors" factory-method="newFixedThreadPool">
<constructor-arg value="5"></constructor-arg>
</bean>
1.创建
ExecutorService executorService = Executors.newFixedThreadPool(threads);
ExecutorService中的 Future<?> submit(Runnable task);会将Runnable方法封装成一个Future对象,只是返回的对象为null,
2.对于<T> Future<T> submit(Callable<T> task);调用返回的Future对象,如果调用future.get(),那么ExecutorService的操作会一直阻塞在那里,直到get()返回值。
3.shutdown()方法会使的ExecutorService 不再接收新的task,但是对正在运行的任何没有任何影响。
4.shutdownNow()方法会给ExecutorService 中的线程执行interrupt()方法,如果task运行的过程中检验这个这个标记,通过Thread.currentThread().isInterrupted()或者Thread.interrupted()方法来检测是否有打断标记,interrupted()方法执行后,打断标记会被清除。