public class HashedTimingWheel extends java.lang.Object implements TimeScheduler, java.lang.Runnable
TimeScheduler. Uses a hashed timing wheel [1].
[1] http://www.cse.wustl.edu/~cdgill/courses/cs6874/TimingWheels.ppt| Modifier and Type | Class and Description |
|---|---|
protected static class |
HashedTimingWheel.MyTask
Simple task wrapper, always executed by at most 1 thread.
|
TimeScheduler.Task| Modifier and Type | Field and Description |
|---|---|
protected static Log |
log |
protected long |
ROTATION_TIME |
protected boolean |
running |
protected long |
tick_time |
protected ThreadFactory |
timer_thread_factory |
protected java.util.List<HashedTimingWheel.MyTask>[] |
wheel |
protected int |
wheel_position |
protected int |
wheel_size |
| Constructor and Description |
|---|
HashedTimingWheel()
Create a scheduler that executes tasks in dynamically adjustable intervals
|
HashedTimingWheel(int corePoolSize) |
HashedTimingWheel(ThreadFactory factory,
int min_threads,
int max_threads,
long keep_alive_time,
int max_queue_size,
int wheel_size,
long tick_time) |
| Modifier and Type | Method and Description |
|---|---|
protected void |
_run() |
java.lang.String |
dumpTimerTasks()
Returns a list of tasks currently waiting for execution.
|
void |
execute(java.lang.Runnable task)
Executes command with zero required delay.
|
int |
getCurrentThreads()
Returns the current threads in the pool, or -1 if not applicable
|
long |
getKeepAliveTime()
Returns the keep alive time (in ms) of the thread pool, or -1 if not applicable
|
int |
getMaxThreads()
Returns the configured max threads, or -1 if not applicable
|
int |
getMinThreads()
Returns the configured core threads, or -1 if not applicable
|
int |
getQueueSize() |
protected void |
init() |
boolean |
isShutdown()
Returns true if stop() has been called, false otherwise
|
void |
run() |
java.util.concurrent.Future<?> |
schedule(java.lang.Runnable work,
long delay,
java.util.concurrent.TimeUnit unit)
Creates and executes a one-shot action that becomes enabled after the given delay.
|
java.util.concurrent.Future<?> |
scheduleAtFixedRate(java.lang.Runnable task,
long initial_delay,
long delay,
java.util.concurrent.TimeUnit unit)
Creates and executes a periodic action that becomes enabled first
after the given initial delay, and subsequently with the given
period; that is executions will commence after
initialDelay then initialDelay+period, then
initialDelay + 2 * period, and so on.
|
java.util.concurrent.Future<?> |
scheduleWithDynamicInterval(TimeScheduler.Task task)
Schedule a task for execution at varying intervals.
|
java.util.concurrent.Future<?> |
scheduleWithFixedDelay(java.lang.Runnable task,
long initial_delay,
long delay,
java.util.concurrent.TimeUnit unit)
Creates and executes a periodic action that becomes enabled first after the given initial delay, and
subsequently with the given delay between the termination of one execution and the commencement of the next.
|
void |
setKeepAliveTime(long time)
Sets the keep alive time (in ms) of the thread pool.
|
void |
setMaxThreads(int size)
Sets the max pool size.
|
void |
setMinThreads(int size)
Sets the core pool size.
|
void |
setThreadFactory(ThreadFactory factory) |
int |
size()
Returns the number of tasks currently in the timer
|
protected void |
startRunner() |
void |
stop()
Stops the timer, cancelling all tasks
|
protected void |
stopRunner() |
java.lang.String |
toString() |
protected volatile boolean running
protected static final Log log
protected ThreadFactory timer_thread_factory
protected int wheel_size
protected long tick_time
protected final long ROTATION_TIME
protected final java.util.List<HashedTimingWheel.MyTask>[] wheel
protected int wheel_position
public HashedTimingWheel()
public HashedTimingWheel(ThreadFactory factory, int min_threads, int max_threads, long keep_alive_time, int max_queue_size, int wheel_size, long tick_time)
public HashedTimingWheel(int corePoolSize)
public void setThreadFactory(ThreadFactory factory)
setThreadFactory in interface TimeSchedulerpublic int getMinThreads()
TimeSchedulergetMinThreads in interface TimeSchedulerpublic void setMinThreads(int size)
TimeSchedulersetMinThreads in interface TimeSchedulerpublic int getMaxThreads()
TimeSchedulergetMaxThreads in interface TimeSchedulerpublic void setMaxThreads(int size)
TimeSchedulersetMaxThreads in interface TimeSchedulerpublic long getKeepAliveTime()
TimeSchedulergetKeepAliveTime in interface TimeSchedulerpublic void setKeepAliveTime(long time)
TimeSchedulersetKeepAliveTime in interface TimeSchedulerpublic int getCurrentThreads()
TimeSchedulergetCurrentThreads in interface TimeSchedulerpublic int getQueueSize()
public java.lang.String dumpTimerTasks()
TimeSchedulerdumpTimerTasks in interface TimeSchedulerpublic void execute(java.lang.Runnable task)
TimeSchedulerexecute in interface TimeSchedulertask - the task to executepublic java.util.concurrent.Future<?> schedule(java.lang.Runnable work,
long delay,
java.util.concurrent.TimeUnit unit)
TimeSchedulerschedule in interface TimeSchedulerwork - the task to executedelay - the time from now to delay executionunit - the time unit of the delay parameterpublic java.util.concurrent.Future<?> scheduleWithFixedDelay(java.lang.Runnable task,
long initial_delay,
long delay,
java.util.concurrent.TimeUnit unit)
TimeSchedulerscheduleWithFixedDelay in interface TimeSchedulertask - the task to executeinitial_delay - the time to delay first executiondelay - the delay between the termination of one execution and the commencement of the nextunit - the time unit of the initialDelay and delay parameterspublic java.util.concurrent.Future<?> scheduleAtFixedRate(java.lang.Runnable task,
long initial_delay,
long delay,
java.util.concurrent.TimeUnit unit)
TimeSchedulerscheduleAtFixedRate in interface TimeSchedulertask - the task to executeinitial_delay - the time to delay first executiondelay - the period between successive executionsunit - the time unit of the initialDelay and period parameterspublic java.util.concurrent.Future<?> scheduleWithDynamicInterval(TimeScheduler.Task task)
HashedTimingWheel.RecurringTask.nextInterval() milliseconds. The task is never done until nextInterval()
return a value <= 0 or the task is cancelled.scheduleWithDynamicInterval in interface TimeSchedulertask - the task to execute
Task is rescheduled relative to the last time it actually started execution
false:public int size()
size in interface TimeSchedulerpublic java.lang.String toString()
toString in class java.lang.Objectpublic void stop()
stop in interface TimeSchedulerjava.lang.InterruptedException - if interrupted while waiting for thread to returnpublic boolean isShutdown()
TimeSchedulerisShutdown in interface TimeSchedulerpublic void run()
run in interface java.lang.Runnableprotected void _run()
protected void init()
protected void startRunner()
protected void stopRunner()
Copyright © 1998-2020 Red Hat. All Rights Reserved.