Как работает MaximumPoolSize ThreadPoolExecutor?
Я пытаюсь понять класс ThreadPoolExecutor. Я прочитал этоответ и Javadoc. Но мои эксперименты нене соответствует этому описанию:
Я инициализирую пул потоков с фабрикой для отслеживания идентификаторов
int tcounter = 0;
ThreadPoolExecutor executor = new ThreadPoolExecutor(2, 4, 1, TimeUnit.MINUTES,
new ArrayBlockingQueue(1000), new ThreadFactory() {
@Override
public Thread newThread(Runnable r) {
return new mThread(tcounter++, r);
}
});
public class mThread extends Thread {
int id;
private mThread(int id, Runnable run) {
super(run);
GLog.e("created thread " + id);
this.id = id;
}
}
тогда задача:
public class mRunanble implements Runnable {
int value = 0;
private mRunanble(int value) {
super();
this.value = value;
}
@Override
public void run() {
SystemClock.sleep(3000);
Thread t = Thread.currentThread();
if (t instanceof mThread) {
GLog.e("Say " + (value) + " on thread " + ((mThread) t).id);
}
}
}
и назначьте кнопке действие:
executor.execute(new mRunanble(i++));
Но я спамил эту кнопку, и третий поток так и не был создан, так что для второго параметра в конструкторе ThreadPoolExecutor (maximumPoolSize=4
). Я планировал создать 4 потока и 2 из них были убиты через 1 минуту после окончания казни