Я работаю над многопоточным проектом, в котором мне нужно создать несколько потоков для измерения сквозной производительности моего клиентского кода, поскольку я выполняю тестирование нагрузки и производительности. Итак, я создал приведенный ниже код, в котором используется ExecutorService
.
Ниже приведен код с ExecutorService
:
public class MultithreadingExample {
public static void main(String[] args) throws InterruptedException {
ExecutorService executor = Executors.newFixedThreadPool(20);
for (int i = 0; i < 100; i++) {
executor.submit(new NewTask());
}
executor.shutdown();
executor.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
}
}
class NewTask implements Runnable {
@Override
public void run() {
//Measure the end to end latency of my client code
}
}
Описание проблемы:
Сейчас я читал какую-то статью в Интернете. Я обнаружил, что есть и ThreadPoolExecutor
. Так что я запутался, какой из них мне следует использовать.
Если я заменю свой код выше:
ExecutorService executor = Executors.newFixedThreadPool(20);
for (int i = 0; i < 100; i++) {
executor.submit(new NewTask());
}
to:
BlockingQueue<Runnable> threadPool = new LinkedBlockingQueue<Runnable>();
ThreadPoolExecutor tpExecutor = new ThreadPoolExecutor(20, 2000, 0L, TimeUnit.MILLISECONDS, threadPool);
tpExecutor.prestartAllCoreThreads();
for (int i = 0; i < 100; i++) {
tpExecutor.execute(new NewTask());
}
это будет иметь значение? Я пытаюсь понять, в чем разница между моим исходным кодом, использующим ExecutorService
, и новым кодом, вставленным с использованием ThreadPoolExecutor
. Некоторые из моих товарищей по команде сказали, что второй (ThreadPoolExecutor) - правильный способ использования.
Кто-нибудь может мне это прояснить?