Package co.paralleluniverse.fibers
Class FiberExecutorScheduler
- java.lang.Object
-
- co.paralleluniverse.fibers.FiberScheduler
-
- co.paralleluniverse.fibers.FiberExecutorScheduler
-
- All Implemented Interfaces:
FiberFactory,StrandFactory,java.util.concurrent.Executor
public class FiberExecutorScheduler extends FiberScheduler implements java.util.concurrent.Executor
A fiber scheduler that uses a givenExecutorfor scheduling. TheRunnabletasks passed to theExecutorfor execution, implement theFiberSchedulerTaskinterface.
-
-
Constructor Summary
Constructors Constructor Description FiberExecutorScheduler(java.lang.String name, java.util.concurrent.Executor executor)Creates a new fiber scheduler with no monitor.FiberExecutorScheduler(java.lang.String name, java.util.concurrent.Executor executor, co.paralleluniverse.common.monitoring.MonitorType monitorType, boolean detailedInfo)Creates a new fiber scheduler.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidexecute(java.lang.Runnable command)java.util.concurrent.ExecutorgetExecutor()protected intgetQueueLength()protected java.util.Map<java.lang.Thread,Fiber>getRunningFibers()protected booleanisCurrentThreadInScheduler()voidshutdown()-
Methods inherited from class co.paralleluniverse.fibers.FiberScheduler
getMonitor, getName, newFiber, newStrand
-
-
-
-
Constructor Detail
-
FiberExecutorScheduler
public FiberExecutorScheduler(java.lang.String name, java.util.concurrent.Executor executor, co.paralleluniverse.common.monitoring.MonitorType monitorType, boolean detailedInfo)Creates a new fiber scheduler.- Parameters:
name- the scheuler's name. This name is used in naming the scheduler's threads.executor- anExecutorused to schedule the fibers; may benullif theexecute(Runnable)method is overriden.monitorType- theMonitorTypetype to use for the scheduler.detailedInfo- whether detailed information about the fibers is collected by the fibers monitor.
-
FiberExecutorScheduler
public FiberExecutorScheduler(java.lang.String name, java.util.concurrent.Executor executor)Creates a new fiber scheduler with no monitor.- Parameters:
name- the scheuler's name. This name is used in naming the scheduler's threads.executor- anExecutorused to schedule the fibers; may benullif theexecute(Runnable)method is overriden.
-
-
Method Detail
-
shutdown
public void shutdown()
- Overrides:
shutdownin classFiberScheduler
-
isCurrentThreadInScheduler
protected boolean isCurrentThreadInScheduler()
- Specified by:
isCurrentThreadInSchedulerin classFiberScheduler
-
getQueueLength
protected int getQueueLength()
- Specified by:
getQueueLengthin classFiberScheduler
-
execute
public void execute(java.lang.Runnable command)
- Specified by:
executein interfacejava.util.concurrent.Executor
-
getRunningFibers
protected java.util.Map<java.lang.Thread,Fiber> getRunningFibers()
-
getExecutor
public java.util.concurrent.Executor getExecutor()
- Specified by:
getExecutorin classFiberScheduler
-
-