Как работает 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 минуту после окончания казни