Jak działa maximumPoolSize z ThreadPoolExecutor?

Próbuję zrozumieć klasę ThreadPoolExecutor. Przeczytałem toodpowiedź i Javadoc. Ale moje eksperymenty nie pasują do tego opisu:

Inicjalizuję pulę wątków z fabryką do śledzenia identyfikatorów

int tcounter = 0;
ThreadPoolExecutor executor = new ThreadPoolExecutor(2, 4, 1, TimeUnit.MINUTES,
        new ArrayBlockingQueue<Runnable>(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;
    }

}

następnie zadanie:

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);
        } 

    }

}

i przypisz przycisk do akcji:

executor.execute(new mRunanble(i++));

Ale spamuję ten przycisk, a trzeci wątek nigdy nie jest tworzony, więc co jest drugim parametrem w konstruktorze ThreadPoolExecutor (maximumPoolSize=4). Spojrzałem na 4 wątki do utworzenia i 2 z nich zabiłem po 1 minucie zakończenia egzekucji

questionAnswers(3)

yourAnswerToTheQuestion