|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectjavax.realtime.util.PooledExecutor
This class represent an abstraction for an Executor
that is actually a pool of Executor
s. The QoS
parameters used to create this class are used as default parameters
for the pool's Executor
s.
NOTE: The basic idea behind executors pool, is that the each
individual executor changes its QoS in order to adjust to the
schedulable entity for which it is running. No schedulability check
is done while changing the QoS, because the change should keep the
system feasible as far as the entity that is using the executor was
considered in the feasibility analysis.
Constructor Summary | |
PooledExecutor(int executorNum,
SchedulingParameters schedulingParam,
ReleaseParameters releaseParam,
MemoryParameters memoryParam,
MemoryArea memoryArea,
ProcessingGroupParameters groupParam,
boolean noHeap)
Creates a new PooledExecutor instance with the
specified parameters. |
Method Summary | |
boolean |
addIfFeasible()
Add to the feasibility of the already set scheduler if the resulting feasibility set is schedulable. |
boolean |
addToFeasibility()
Inform the scheduler and cooperating facilities that the resource demands (as expressed in the associated instances of SchedulingParameters, ReleaseParameters, MemoryParameters, and ProcessingGroupParameters) of this instance of Schedulable will be considered in the feasibility analysis of the associated Scheduler until further notice. |
void |
execute(Runnable task)
Executes the given logic. |
int |
executionEligibility()
NOTE: This method is not part of the RTSJ Specification. |
MemoryParameters |
getMemoryParameters()
Get the MemoryParameters of this schedulable object. |
ProcessingGroupParameters |
getProcessingGroupParameters()
Get the ProcessingGroupParameters of this
schedulable object. |
ReleaseParameters |
getReleaseParameters()
Get the ReleaseParameters of this schedulable object. |
Scheduler |
getScheduler()
Get the Scheduler for this schedulable object. |
SchedulingParameters |
getSchedulingParameters()
Get the SchedulingParameters for this schedulable object. |
boolean |
removeFromFeasibility()
Inform the scheduler and cooperating facilities that the resource demands, as expressed in the associated instances of SchedulingParameters , ReleaseParameters , MemoryParameters , and ProcessingGroupParameters , of
this instance of Schedulable should no longer be
considered in the feasibility analysis of the associated Scheduler . |
void |
run()
|
void |
setMemoryParameters(MemoryParameters memoryParam)
Set the MemoryParameters for this schedulable object. |
boolean |
setMemoryParametersIfFeasible(MemoryParameters memoryParam)
Returns true if, after considering the value of the parameter, the task set would still be feasible. |
void |
setProcessingGroupParameters(ProcessingGroupParameters groupParam)
Set the ProcessingGroupParameters for this schedulable object. |
boolean |
setProcessingGroupParametersIfFeasible(ProcessingGroupParameters groupParam)
Set the ProcessingGroupParameters of this schedulable object
only if the resulting task set is feasible. |
void |
setReleaseParameters(ReleaseParameters releaseParam)
Set the ReleaseParameters for this schedulable object. |
boolean |
setReleaseParametersIfFeasible(ReleaseParameters releaseParam)
Returns true if, after considering the value of the parameter, the task set would still be feasible. |
void |
setScheduler(Scheduler scheduler)
Set the Scheduler for this schedulable object. |
void |
setScheduler(Scheduler scheduler,
SchedulingParameters schedulingParam,
ReleaseParameters releaseParam,
MemoryParameters memoryParam,
ProcessingGroupParameters groupParam)
Set the Scheduler for this schedulable object. |
void |
setSchedulingParameters(SchedulingParameters schedulingParam)
Set the SchedulingParameters for this schedulable
object only if the resulting task set is feasible. |
boolean |
setSchedulingParametersIfFeasible(SchedulingParameters schedulingParam)
Set the SchedulingParameters for this schedulable object. |
void |
shutdown()
Releases all the resources assoiated with the executor. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
public PooledExecutor(int executorNum, SchedulingParameters schedulingParam, ReleaseParameters releaseParam, MemoryParameters memoryParam, MemoryArea memoryArea, ProcessingGroupParameters groupParam, boolean noHeap) throws IllegalArgumentException
PooledExecutor
instance with the
specified parameters.
schedulingParam
- a SchedulingParameters
value
which will be associated with the constructed instance of this.
If null
this will be assigned the reference to the
SchedulingParameters
of the current thread.releaseParam
- a ReleaseParameters
value
which will be associated with the constructed instance of this.
If null this will have no ReleaseParameters
.memoryParam
- a MemoryParameters
value which
will be associated with the constructed instance of this. If
null this will have no MemoryParameters
.memoryArea
- The MemoryArea
for this
PooledExecutor
. If null, inherit the current
memory area at the time of construction. The initial memory
area must be a reference to a ScopedMemory
or ImmortalMemory
object if noheap
is
true
.groupParam
- A ProcessingGroupParameters
object
to which this will be associated. If null this will not be
associated with any processing group.noHeap
- A flag meaning, when true
, that this
will have characteristics identical to a NoHeapRealtimeThread
. A false value means this will have
characteristics identical to a RealtimeThread
. If
true
and the current thread is not a NoHeapRealtimeThread
or a RealtimeThread
executing
within a ScopedMemory
or ImmortalMemory
scope
then an IllegalArgumentException
is thrown.Method Detail |
public void execute(Runnable task) throws ShutdownExecutorException
Executor
execute
in interface Executor
task
- a Runnable
value
ShutdownExecutorException
- if the
Executor
has already been shut down.public void shutdown()
Executor
execute()
method
should be performed after the executor has been shutdown.
shutdown
in interface Executor
public boolean addIfFeasible()
addIfFeasible
in interface Schedulable
public boolean addToFeasibility()
addToFeasibility
in interface Schedulable
public MemoryParameters getMemoryParameters()
MemoryParameters
of this schedulable object.
getMemoryParameters
in interface Schedulable
MemoryParameters
value.public void setMemoryParameters(MemoryParameters memoryParam)
MemoryParameters
for this schedulable object.
setMemoryParameters
in interface Schedulable
memoryParam
- the MemoryParameters
for this
schedulable object.public boolean setMemoryParametersIfFeasible(MemoryParameters memoryParam)
setMemoryParametersIfFeasible
in interface Schedulable
memoryParam
- the MemoryParameters
for this
schedulable object.
public ProcessingGroupParameters getProcessingGroupParameters()
ProcessingGroupParameters
of this
schedulable object.
getProcessingGroupParameters
in interface Schedulable
ProcessingGroupParameters
valuepublic void setProcessingGroupParameters(ProcessingGroupParameters groupParam)
ProcessingGroupParameters
for this schedulable object.
setProcessingGroupParameters
in interface Schedulable
groupParam
- a ProcessingGroupParameters
valuepublic boolean setProcessingGroupParametersIfFeasible(ProcessingGroupParameters groupParam)
ProcessingGroupParameters
of this schedulable object
only if the resulting task set is feasible.
setProcessingGroupParametersIfFeasible
in interface Schedulable
groupParam
- a ProcessingGroupParameters
value
public ReleaseParameters getReleaseParameters()
ReleaseParameters
of this schedulable object.
getReleaseParameters
in interface Schedulable
ReleaseParameters
valuepublic void setReleaseParameters(ReleaseParameters releaseParam)
ReleaseParameters
for this schedulable object.
setReleaseParameters
in interface Schedulable
releaseParam
- a ReleaseParameters
valuepublic boolean setReleaseParametersIfFeasible(ReleaseParameters releaseParam)
setReleaseParametersIfFeasible
in interface Schedulable
releaseParam
- a ReleaseParameters
valuepublic Scheduler getScheduler()
Scheduler
for this schedulable object.
getScheduler
in interface Schedulable
Scheduler
valuepublic void setScheduler(Scheduler scheduler) throws IllegalThreadStateException
Scheduler
for this schedulable object.
setScheduler
in interface Schedulable
scheduler
- the scheduler.
IllegalThreadStateException
public void setScheduler(Scheduler scheduler, SchedulingParameters schedulingParam, ReleaseParameters releaseParam, MemoryParameters memoryParam, ProcessingGroupParameters groupParam) throws IllegalThreadStateException
Scheduler
for this schedulable object.
setScheduler
in interface Schedulable
scheduler
- a Scheduler
valueschedulingParam
- a SchedulingParameters
valuereleaseParam
- a ReleaseParameters
valuememoryParam
- a MemoryParameters
valuegroupParam
- a ProcessingGroupParameters
value
IllegalThreadStateException
- if an error occurspublic SchedulingParameters getSchedulingParameters()
SchedulingParameters
for this schedulable object.
getSchedulingParameters
in interface Schedulable
SchedulingParameters
valuepublic void setSchedulingParameters(SchedulingParameters schedulingParam)
SchedulingParameters
for this schedulable
object only if the resulting task set is feasible.
setSchedulingParameters
in interface Schedulable
schedulingParam
- a SchedulingParameters
valuepublic boolean setSchedulingParametersIfFeasible(SchedulingParameters schedulingParam)
SchedulingParameters
for this schedulable object.
setSchedulingParametersIfFeasible
in interface Schedulable
schedulingParam
- a SchedulingParameters
value
public boolean removeFromFeasibility()
SchedulingParameters
, ReleaseParameters
, MemoryParameters
, and ProcessingGroupParameters
, of
this instance of Schedulable
should no longer be
considered in the feasibility analysis of the associated Scheduler
. Whether the resulting system is feasible or not,
the subtrac-tion is completed.
removeFromFeasibility
in interface Schedulable
public int executionEligibility()
Schedulable
executionEligibility
in interface Schedulable
int
value used internally to represent
a total ordering of the schedulable entities.public void run()
run
in interface Runnable
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |