Вызываемый интерфейс со структурой исполнителя. Почему программа не вышла даже после возврата из метода вызова

Я пытаюсь понять вызываемый интерфейс с Executor Framework . Это работает, но я немного запутался, почему программа не завершается даже после возврата из метода вызова.

Код:

CallableExample.java

package callable1;

import java.util.concurrent.Callable;

public class CallableExample implements Callable<String> {

    @Override
    public String call() throws Exception {
        // TODO Auto-generated method stub
        String s = Thread.currentThread().getName();
        for(int i = 0 ; i < 10 ; i++)
        {
            s += ""+i;
            System.out.println(s);
            Thread.sleep(1000);
        }

        return s;
    }
}

Tester.java

package callable1;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class Tester {

    public static void main(String[] args) throws Exception
    {
        ExecutorService pool = Executors.newFixedThreadPool(5);
        Future<String> ftask = pool.submit(new CallableExample());

        System.out.println("getting result");
        System.out.println("----" + ftask.get());
        System.out.println("main over");
    }
}

1 ответ

Нитки бассейнов java.util.concurrent.* разработаны таким образом, поэтому вы должны позвонить либо shutdown() или же shutdownNow() на вашего исполнителя. В противном случае программа не остановится. Вы можете найти разницу между методами в Javadocs.

Другие вопросы по тегам