jasima.core.expExecution.ThreadPoolExecutor Maven / Gradle / Ivy
/*******************************************************************************
* This file is part of jasima, v1.3, the Java simulator for manufacturing and
* logistics.
*
* Copyright (c) 2015 jasima solutions UG
* Copyright (c) 2010-2015 Torsten Hildebrandt and jasima contributors
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
*******************************************************************************/
package jasima.core.expExecution;
import jasima.core.experiment.Experiment;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicInteger;
/**
*
* Default implementation of an ExecutorFactory returning an Executor that uses
* up to {@code Runtime.getRuntime().availableProcessors()} threads to execute
* tasks concurrently. This number of threads can be overridden by setting the
* system property "jasima.core.expExecution.ThreadPoolExecutor.numThreads".
*
*
* In order to prevent starvation of worker threads waiting for sub-experiments
* to complete, there is a thread pool for each nesting level of experiments.
*
*
* @author Torsten Hildebrandt
* @version
* "$Id: ThreadPoolExecutor.java 753 2015-07-27 15:29:49Z [email protected] $"
*/
public class ThreadPoolExecutor extends ExperimentExecutor {
public static final String POOL_SIZE_SETTING = ThreadPoolExecutor.class
.getName() + ".numThreads";
// an executor service for each nesting level
private Map insts = new HashMap();
protected ThreadPoolExecutor() {
super();
}
@Override
public ExperimentFuture runExperiment(final Experiment e,
final Experiment parent) {
ExecutorService es = getExecutorInstance(e.nestingLevel());
return new FutureWrapper(e,
es.submit(new Callable