twisted._threads.Team(object)
class documentationtwisted._threads
View Source
(View In Hierarchy)
Implements interfaces: .IWorker
A composite IWorker
implementation.
Method | __init__ | No summary |
Method | statistics | Gather information on the current status of this Team . |
Method | grow | Increase the the number of idle workers by n . |
Method | shrink | Decrease the number of idle workers by n . |
Method | do | Perform some work in a worker created by createWorker . |
Method | quit | Stop doing work and shut down all idle workers. |
Instance Variable | _quit | A Quit
flag indicating whether this Team has been quit yet.
This may be set by an arbitrary thread since Team.quit may be
called from anywhere. |
Instance Variable | _coordinator | the IExclusiveWorker
coordinating access to this Team 's internal
resources. |
Instance Variable | _createWorker | a callable that will create new workers. |
Instance Variable | _logException | a 0-argument callable called in an exception context when there is an
unhandled error from a task passed to Team.do |
Instance Variable | _idle | a set
of idle workers. |
Instance Variable | _busyCount | the number of workers currently busy. |
Instance Variable | _pending | a deque of tasks - that is, 0-argument callables passed to Team.do - that are
outstanding. |
Instance Variable | _shouldQuitCoordinator | A flag indicating that the coordinator should be quit at the next available
opportunity. Unlike Team._quit , this
flag is only set by the coordinator. |
Instance Variable | _toShrink | the number of workers to shrink this Team by at the next
available opportunity; set in the coordinator. |
Method | _quitIdlers | The implmentation of shrink , performed by the coordinator
worker. |
Method | _coordinateThisTask | Select a worker to dispatch to, either an idle one or a new one, and perform it. |
Method | _recycleWorker | Called only from coordinator. |
Team.do
deque
of tasks - that is, 0-argument callables passed to Team.do
- that are
outstanding.
Team._quit
, this
flag is only set by the coordinator.
Team
by at the next
available opportunity; set in the coordinator.
Parameters | coordinator | an IExclusiveWorker
which will coordinate access to resources on this Team ; that is to say, an
IExclusiveWorker
whose do method ensures that its given work will be executed
in a mutually exclusive context, not in parallel with other work enqueued
by do (although possibly in parallel with the caller). |
createWorker | A 0-argument callable that will create an IWorker to perform
work. | |
logException | A 0-argument callable called in an exception context when the work passed
to do raises an exception. |
Gather information on the current status of this Team
.
Returns | a Statistics
describing the current state of this Team . |
Increase the the number of idle workers by n
.
Parameters | n | The number of new idle workers to create. (type: int ) |
Decrease the number of idle workers by n
.
Parameters | n | The number of idle workers to shut down, or None (or
unspecified) to shut down all workers. (type: int
or types.NoneType ) |
The implmentation of shrink
, performed by the coordinator
worker.
Parameters | n | see Team.shrink |
Perform some work in a worker created by createWorker
.
Parameters | task | the callable to run |
Select a worker to dispatch to, either an idle one or a new one, and perform it.
This method should run on the coordinator worker.
Parameters | task | the task to dispatch (type: 0-argument callable) |