1. 首先,我们需要创建两个ExecutorService对象,这两个对象将作为我们的缓存线程池。
2. 然后,我们使用嵌套的for循环来执行我们的操作。在每个外层循环中,我们将创建一个新的任务并提交给外层线程池。在这个任务中,我们将创建一个新的内层循环,并在每个内层循环中创建一个新的任务并提交给内层线程池。
3. 最后,我们需要确保所有的任务都已经完成,所以我们需要调用ExecutorService的shutdown方法来关闭线程池。
public static ThreadFactory resizeImageThreadFactory = new ThreadFactoryBuilder ( ) . setNameFormat ( "resizeImageThread-pool-%d" ) . build ( ) ; public static ExecutorService outerExecutor = Executors . newCachedThreadPool ( resizeImageThreadFactory) ; public static ExecutorService innerExecutor = Executors . newCachedThreadPool ( resizeImageThreadFactory) ;
import java. util. concurrent. * ; public class NestedLoopWithThreadPools { public static void main ( String [ ] args) throws InterruptedException , ExecutionException { for ( int i = 0 ; i < 10 ; i++ ) { final int outerIndex = i; outerExecutor. submit ( ( ) -> { for ( int j = 0 ; j < 10 ; j++ ) { final int innerIndex = j; innerExecutor. submit ( ( ) -> { System . out. println ( "Outer loop index: " + outerIndex + ", Inner loop index: " + innerIndex) ; } ) ; } } ) ; } outerExecutor. shutdown ( ) ; innerExecutor. shutdown ( ) ; }
}