All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.gh.bmd.jrt.runner.ScheduledRunner Maven / Gradle / Ivy

There is a newer version: 5.9.0
Show newest version
/*
 * 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.gh.bmd.jrt.runner;

import com.gh.bmd.jrt.util.WeakIdentityHashMap;

import java.util.Collections;
import java.util.Map;
import java.util.WeakHashMap;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;

import javax.annotation.Nonnull;

/**
 * Class implementing a runner employing an executor service.
 * 

* Created by davide-maestroni on 10/14/14. */ class ScheduledRunner implements Runner { private final WeakIdentityHashMap, Void>> mFutures = new WeakIdentityHashMap, Void>>(); private final ScheduledExecutorService mService; private final Map mThreads = Collections.synchronizedMap(new WeakIdentityHashMap()); /** * Constructor. * * @param service the executor service. */ @SuppressWarnings("ConstantConditions") ScheduledRunner(@Nonnull final ScheduledExecutorService service) { if (service == null) { throw new NullPointerException("the executor service must not be null"); } mService = service; } public void cancel(@Nonnull final Execution execution) { synchronized (mFutures) { final WeakHashMap, Void> scheduledFutures = mFutures.remove(execution); if (scheduledFutures != null) { for (final ScheduledFuture future : scheduledFutures.keySet()) { future.cancel(false); } } } } public boolean isExecutionThread() { return mThreads.containsKey(Thread.currentThread()); } public void run(@Nonnull final Execution execution, final long delay, @Nonnull final TimeUnit timeUnit) { final ScheduledFuture future = mService.schedule(new ExecutionWrapper(execution, mThreads), delay, timeUnit); if (execution.mayBeCanceled()) { synchronized (mFutures) { final WeakIdentityHashMap, Void>> futures = mFutures; WeakHashMap, Void> scheduledFutures = futures.get(execution); if (scheduledFutures == null) { scheduledFutures = new WeakHashMap, Void>(); futures.put(execution, scheduledFutures); } scheduledFutures.put(future, null); } } } /** * Class used to keep track of the threads employed by this runner. */ private static class ExecutionWrapper implements Runnable { private final Thread mCurrentThread; private final Execution mExecution; private final Map mThreads; /** * Constructor. * * @param wrapped the wrapped execution. * @param threads the map of runner threads. */ private ExecutionWrapper(@Nonnull final Execution wrapped, @Nonnull final Map threads) { mExecution = wrapped; mThreads = threads; mCurrentThread = Thread.currentThread(); } public void run() { final Thread currentThread = Thread.currentThread(); if (currentThread != mCurrentThread) { mThreads.put(currentThread, null); } mExecution.run(); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy