Class AdjustableCallback
A timer is started as either recurring or non-recurring, and recurring mode can be toggled while the timer is running. Once the timer fires in non-recurring mode, it never fires again. However, if the timer is then re-started, the current recurring mode remains in effect.
When setting the delay for a timer, there are two methods that behave slightly differently:
-  setDelay(): If the timer is not running, the delay value is used as the new delay value. If the timer is running, then the amount of wait time on the current timer is deducted from the delay for the first cycle of the timer. The intention is that if a timer was set to 60 minutes and the timer has already waited 45 minutes and the delay is then changed to 15 minutes, the timer has already waited long enough to trigger from a real world perspective. This is typically desirable behavior so that QA can shorten timers for testing and not have to wait excessively for the first cycle. This is also useful for operations when adjusting settings on live equipment.
-  setAbsDelay(): The delay is always treated as absolute.
There are two properties that control variability of the effective delay:
-  minVariance: This is the lower bound on the variance and must be less than or equal tomaxVariance. This defaults to 1.0 and can be adjusted to the desired lower limit. For example, to allow the effective timer to be up to 25% shorter than the specified delay, the value can be set to 0.75 (75% of specified delay).
-  maxVariance: This is the upper bound on the variance and must be greater than or equal tominVariance. This defaults to 1.0 and can be adjusted to the desired upper limit. For example, to allow the effective timer to be up to 25% longer than the specified delay, the value can be set to 1.25 (125% of the specified delay).
- Since:
- 1.0
- Version:
- 2022-10-12
- 
Constructor SummaryConstructorsConstructorDescriptionAdjustableCallback(boolean recurring, int delay, Runnable callback) Creates a timer with the specifiedcallbackmethod,delay, andrecurringflag.AdjustableCallback(boolean recurring, Runnable callback) Creates a timer with the specifiedcallbackmethod andrecurringflag.AdjustableCallback(Runnable callback) Creates a non-recurring timer with the specifiedcallbackmethod.
- 
Method SummaryModifier and TypeMethodDescriptionintgetDelay()Returns the timer's configured delay.doubleRetrieves the maximum delay variance.doubleRetrieves the minimum delay variance.booleanIndicates if this is a recurring timer or not.setAbsDelay(int delay) Sets the delay for the timer, regardless of how much time is left on the current timer.booleanSet the callback to fire at the specified date.setDayRelative(int secFromMidnight) Sets the delay for the timer, regardless of how much time is left on the current timer.setDelay(int delay) Sets a new delay value for the timer.setMaxVariance(double maxVariance) Sets the maximum delay variance.setMinVariance(double minVariance) Sets the minimum delay variance.setRecurring(boolean recurring) Sets therecurringflag.start()Starts the timer.stop()Stops the timer.Methods inherited from class com.tccc.kos.commons.util.concurrent.BaseCallbackcancel, flush, flushInline, force, forceInline, getCallback, getWaitTime, isRunning, isStopped
- 
Constructor Details- 
AdjustableCallbackCreates a non-recurring timer with the specifiedcallbackmethod. The timer does not automatically start. Instead, it waits until the calling code calls thestart()method.- Parameters:
- callback- the method called when the timer fires
 
- 
AdjustableCallbackCreates a timer with the specifiedcallbackmethod andrecurringflag. The timer does not automatically start. Instead, it waits until the calling code calls thestart()method.- Parameters:
- recurring-- truefor a recurring timer,- falsefor a one-shot timer
- callback- the method called when the timer fires
 
- 
AdjustableCallbackCreates a timer with the specifiedcallbackmethod,delay, andrecurringflag. The timer starts immediately.- Parameters:
- recurring-- truefor a recurring timer,- falsefor a one-shot timer
- delay- the initial delay for the timer
- callback- the method called when the timer fires
 
 
- 
- 
Method Details- 
isRecurringpublic boolean isRecurring()Indicates if this is a recurring timer or not.- Returns:
- trueif this a recurring timer,- falseif a one-shot timer
 
- 
setRecurringSets therecurringflag.- Parameters:
- recurring-- trueto make this timer recurring, or- falseto make it a one-shot timer
 
- 
getDelaypublic int getDelay()Returns the timer's configured delay.- Returns:
- the delay time (msec)
 
- 
setDelaySets a new delay value for the timer.- If the timer is already running, then the amount of time already waited is subtracted from the new delay. The timer is restarted with this new delay.
- If the timer is not running, then only the delay value is updated; the timer is not started.
 setAbsDelay().- Parameters:
- delay- the delay (msec)
 
- 
getMinVariancepublic double getMinVariance()Retrieves the minimum delay variance.- Returns:
- the min delay variance
 
- 
setMinVarianceSets the minimum delay variance.- Parameters:
- minVariance- the min variance, any non-negative number
 
- 
getMaxVariancepublic double getMaxVariance()Retrieves the maximum delay variance.- Returns:
- the max delay variance
 
- 
setMaxVarianceSets the maximum delay variance.- Parameters:
- maxVariance- the max variance, any non-negative number
 
- 
setAbsDelaySets the delay for the timer, regardless of how much time is left on the current timer.- If the timer is currently running, then it is stopped and restarted.
- If the timer is currently stopped, it remains stopped.
 - Parameters:
- delay- the delay (msec)
 
- 
setDayRelativeSets the delay for the timer, regardless of how much time is left on the current timer. The delay will be computed using day relative semantics. If the current local time is before the day relative time, the timer will trigger on the day relative time today. If current local time is after the day relative time, the timer will trigger tomorrow at the day relative time.- If the timer is currently running, then it is stopped and restarted.
- If the timer is currently stopped, it remains stopped.
 Day relative time is useful for events that must occur at the next occurrence of a local time. This should be used in conjunction with TimeChangeListenerso the timer can be rebuilt if the local time or timezone changes.When used in recurring mode, the first callback will be at the next occurrence of the specified day relative time and subsequent callbacks will be on 24 hour intervals. - Parameters:
- secFromMidnight- day relative time in seconds from midnight
 
- 
startStarts the timer.- If the timer is currently stopped, then it is started.
- If the timer is currently running, then this call has no effect.
 
- 
stopStops the timer. Callscancel()and exists for api symmetry.
- 
setDateSet the callback to fire at the specified date. This will set the delay to the specified date and automatically start the timer. If the date is in the past, the timer will not be started. Return true if the timer is started. This will clear the recurring flag on the callback if set.- Parameters:
- date- the date to perform the callback
 
 
-