com.datumbox.framework.common.concurrency.ThreadMethods Maven / Gradle / Ivy
/**
* Copyright (C) 2013-2016 Vasilis Vryniotis
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.datumbox.framework.common.concurrency;
import java.util.concurrent.*;
import java.util.function.Consumer;
import java.util.stream.Stream;
/**
* This class contains a number of helper methods for Java 8 Threads.
*
* @author Vasilis Vryniotis
*/
public class ThreadMethods {
/**
* Takes the items of the stream in a throttled way and provides them to the
* consumer. It uses as many threads as the available processors and it does
* not start more tasks than 2 times the previous number.
*
* @param
* @param stream
* @param consumer
* @param concurrencyConfig
*/
public static void throttledExecution(Stream stream, Consumer consumer, ConcurrencyConfiguration concurrencyConfig) {
if(concurrencyConfig.isParallelized()) {
int maxThreads = concurrencyConfig.getMaxNumberOfThreadsPerTask();
int maxTasks = 2*maxThreads;
ExecutorService executorService = Executors.newFixedThreadPool(maxThreads);
ThrottledExecutor executor = new ThrottledExecutor(executorService, maxTasks);
stream.sequential().forEach(i -> {
executor.execute(() -> {
consumer.accept(i);
});
});
executorService.shutdown();
try {
executorService.awaitTermination(Integer.MAX_VALUE, TimeUnit.SECONDS);
}
catch (InterruptedException ex) {
throw new RuntimeException(ex);
}
}
else {
Runnable runnable = () -> stream.forEach(consumer);
runnable.run();
}
}
/**
* Alternative to parallelStreams() which executes a callable in a separate
* pool.
*
* @param
* @param callable
* @param concurrencyConfig
* @param parallelStream
* @return
*/
public static T forkJoinExecution(Callable callable, ConcurrencyConfiguration concurrencyConfig, boolean parallelStream) {
if(parallelStream && concurrencyConfig.isParallelized()) {
try {
ForkJoinPool pool = new ForkJoinPool(concurrencyConfig.getMaxNumberOfThreadsPerTask());
T results = pool.submit(callable).get();
pool.shutdown();
return results;
}
catch (InterruptedException | ExecutionException ex) {
throw new RuntimeException(ex);
}
}
else {
try {
return callable.call();
}
catch (Exception ex) {
throw new RuntimeException(ex);
}
}
}
/**
* Alternative to parallelStreams() which executes a runnable in a separate
* pool.
*
* @param runnable
* @param concurrencyConfig
* @param parallelStream
*/
public static void forkJoinExecution(Runnable runnable, ConcurrencyConfiguration concurrencyConfig, boolean parallelStream) {
if(parallelStream && concurrencyConfig.isParallelized()) {
try {
ForkJoinPool pool = new ForkJoinPool(concurrencyConfig.getMaxNumberOfThreadsPerTask());
pool.submit(runnable).get();
pool.shutdown();
}
catch (InterruptedException | ExecutionException ex) {
throw new RuntimeException(ex);
}
}
else {
runnable.run();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy