Исполнитель ThreadPool, сборка мусора

Я использую исполнитель ThreadPool в цикле do while в качестве процесса deamon. В начале каждой итерации я создаю newFixedThreadPool: executor = Executors.newFixedThreadPool (5);

После завершения задачи я вызываю завершение работы до начала следующей итерации, и newFixedPool создается для новых 5 рабочих потоков.

Теперь при печати журналов Log4J. Я использую [% t], чтобы показать, какой пул потоков выполняется. Я вижу, что для каждой итерации создается новый пул потоков с увеличивающимся числом.

Пожалуйста, дайте мне знать, нужно ли мне вызывать executeor = null перед началом следующей итерации?

Указывает ли увеличенный пул потоков, что пул потоков накапливается и может привести к утечке памяти, поскольку это процесс deamon, или пул потоков на задней стороне будет собирать мусор, поскольку все потоки были завершены, и мы уже выполнили завершение работы.

 2014-06-26 16:26:11,548 [47    ] [INFO ][pool-1-thread-1] - Started processing new         payments for serverID: 5
2014-06-26 16:26:11,548 [47    ] [INFO ][pool-1-thread-2] - Started processing new payments for serverID: 6
2014-06-26 16:26:11,548 [47    ] [INFO ][pool-1-thread-3] - Started processing new payments for serverID: 7
2014-06-26 16:26:11,548 [47    ] [INFO ][pool-1-thread-4] - Started processing new payments for serverID: 8
2014-06-26 16:26:11,548 [47    ] [INFO ][pool-1-thread-5] - Started processing new payments for serverID: 9
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-2] - Completed processing new payments for serverID: 6
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-5] - Completed processing new payments for serverID: 9
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-2] - Time taken to Process new payments for serverId 6 : 12 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-5] - Time taken to Process new payments for serverId 9 : 12 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-3] - Completed processing new payments for serverID: 7
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-1] - Completed processing new payments for serverID: 5
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-3] - Time taken to Process new payments for serverId 7 : 12 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-1] - Time taken to Process new payments for serverId 5 : 12 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-4] - Completed processing new payments for serverID: 8
2014-06-26 16:26:24,129 [12628 ] [INFO ][pool-1-thread-4] - Time taken to Process new payments for serverId 8 : 12 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][main] - ShutDown complete
2014-06-26 16:26:24,129 [12628 ] [INFO ][main] - ProcessDeamon iteration finished in 0 Sec 
2014-06-26 16:26:24,129 [12628 ] [INFO ][main] - ProcessDeamon iteration started
2014-06-26 16:26:24,191 [12690 ] [INFO ][pool-2-thread-1] - Started processing new payments for serverID: 5
2014-06-26 16:26:24,191 [12690 ] [INFO ][pool-2-thread-2] - Started processing new payments for serverID: 6
2014-06-26 16:26:24,191 [12690 ] [INFO ][pool-2-thread-3] - Started processing new payments for serverID: 7
2014-06-26 16:26:24,191 [12690 ] [INFO ][pool-2-thread-4] - Started processing new payments for serverID: 8
2014-06-26 16:26:24,191 [12690 ] [INFO ][pool-2-thread-5] - Started processing new payments for serverID: 9

2014-06-26 16:26:34,443 [22942 ] [INFO ][pool-2-thread-2] - Completed processing new payments for serverID: 6
2014-06-26 16:26:34,443 [22942 ] [INFO ][pool-2-thread-2] - Time taken to Process new payments for serverId 6 : 10 Sec 
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-4] - Completed processing new payments for serverID: 8
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-3] - Completed processing new payments for serverID: 7
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-5] - Completed processing new payments for serverID: 9
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-4] - Time taken to Process new payments for serverId 8 : 10 Sec 
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-3] - Time taken to Process new payments for serverId 7 : 10 Sec 
2014-06-26 16:26:34,490 [22989 ] [INFO ][pool-2-thread-5] - Time taken to Process new payments for serverId 9 : 10 Sec 
2014-06-26 16:26:34,521 [23020 ] [INFO ][pool-2-thread-1] - Completed processing new payments for serverID: 5
2014-06-26 16:26:34,521 [23020 ] [INFO ][pool-2-thread-1] - Time taken to Process new payments for serverId 5 : 10 Sec 
2014-06-26 16:26:34,521 [23020 ] [INFO ][main] - ShutDown complete
2014-06-26 16:26:34,521 [23020 ] [INFO ][main] - ProcessDeamon iteration finished in 0 Sec 
2014-06-26 16:26:34,521 [23020 ] [INFO ][main] - ProcessDeamon iteration started

person Apt    schedule 26.06.2014    source источник


Ответы (1)


Не выключайте Threadpool, а используйте его повторно. В этом весь смысл пула потоков: вы отправляете задачи в этот пул и не должны заботиться об управлении потоками. Просто дождитесь завершения ваших потоков и отправьте следующий пакет задач в тот же пул.

person Jonathan    schedule 26.06.2014
comment
Я не могу использовать повторно ... так как я хочу, чтобы все итерации были согласованными. По этой причине я вызываю выключение ... а затем жду в неопределенном цикле, чтобы проверить, завершен ли исполнитель. После завершения работы ... нельзя повторно использовать тот же пул ... как из документации ... исполнитель не примет новую задачу .. - person Apt; 26.06.2014
comment
Пожалуйста, прочтите и поймите API ThreadpoolExecutor. Не ждите в бесконечном цикле, а используйте awaitTermination. Если вы хотите выполнить несколько пакетов задач в одном Threadpool, не завершайте работу этого пула, а подождите, пока getActiveCount == 0 станет истинным - person Jonathan; 27.06.2014