shutdown and awaitTermination which first call have any difference?

前端 未结 9 1186
渐次进展
渐次进展 2020-12-12 14:44

What is the difference between

ExecutorService eService = Executors.newFixedThreadPool(2);
eService.execute(new TestThread6());
eService.execute(new TestThre         


        
相关标签:
9条回答
  • 2020-12-12 14:55

    Reading the documentation always helps:

    shutdownNow :

    Attempts to stop all actively executing tasks, halts the processing of waiting tasks, and returns a list of the tasks that were awaiting execution. These tasks are drained (removed) from the task queue upon return from this method.

    This method does not wait for actively executing tasks to terminate. Use awaitTermination to do that.

    There are no guarantees beyond best-effort attempts to stop processing actively executing tasks. This implementation cancels tasks via Thread.interrupt(), so any task that fails to respond to interrupts may never terminate

    shutdown:

    Initiates an orderly shutdown in which previously submitted tasks are executed, but no new tasks will be accepted. Invocation has no additional effect if already shut down.

    This method does not wait for previously submitted tasks to complete execution. Use awaitTermination to do that.

    awaitTermination:

    Blocks until all tasks have completed execution after a shutdown request, or the timeout occurs, or the current thread is interrupted, whichever happens first.

    0 讨论(0)
  • 2020-12-12 14:56

    shutdown means the executor service takes no more incoming tasks.

    awaitTermination is invoked after a shutdown request.

    You need to first shut down the service and then block and wait for threads to finish.

    If you want to see all threads finish running and insist on using awaiTermination, you need to set the timeout parameter to be big enough. So you could do:

    eService.shutdown();
    if (!eService.awaitTermination(60000, TimeUnit.SECONDS))
        System.err.println("Threads didn't finish in 60000 seconds!");
    }
    

    Alternatively, you could do:

    eService.shutdown();
    while (!eService.isTerminated()) {
    
    }
    

    This way you are able to ensure all threads are finished running unless they are interrupted unexpectedly.

    0 讨论(0)
  • 2020-12-12 14:58

    the best implementation:

    executor.shutdown();
        try {
             if (!executor.awaitTermination(3500, TimeUnit.MILLISECONDS)) {
                executor.shutdownNow();
             }                  
        } catch (InterruptedException e) {              
            executor.shutdownNow();
        }
    
    0 讨论(0)
  • 2020-12-12 14:59

    After we start the first task ThreadPoolExecutor will start a Thread that will not end even after the task is finished. At least it's true for a fixed thread pool. This is why we need to call shutdown. After shutdown ThreadPoolExecutor will reject any new task but will wait for running tasks to finish and then allow the Threads to end. This is why we need awaitTermination after shutdwon.

    0 讨论(0)
  • 2020-12-12 15:00

    You should call shutdown first. Otherwise, you might be waiting for a very long time, since awaitTermination doesn't actually shut down your executor.

    If you wanted to wait for tasks to complete, rather than wait for the executor to shut down, then you should use invokeAll.

    0 讨论(0)
  • 2020-12-12 15:02
    executorService.execute(runnableTask);  
    
    //executorService.shutdown(); //it will make the executorService stop accepting new tasks
    //executorService.shutdownNow(); //tires to destroy the executorService immediately, but it doesn't guarantee that all the running threads will be destroyed at the same time. This method returns list of tasks which are waiting to be processed.
    //List<Runnable> notExecutedTasks = executorService.shutdownNow(); //this method returns list of tasks which are waiting to be processed.developer decide what to do with theses tasks?
    
    //one good way to shutdown the executorService is use both of these methods combined with the awaitTermination
    executorService.shutdown();
    try{
        if(!executorService.awaitTermination(1000, TimeUnit.MICROSECONDS)) {
            executorService.shutdownNow();
        }
    }catch (InterruptedException e){
        e.printStackTrace();
    }
    
    0 讨论(0)
提交回复
热议问题