Represent an Operation Awaiting Completion
A 'Future' object represents an operation that is currently in progress, or has recently completed. It can be used in a variety of ways to manage the flow of control, and data, through an asynchronous program.
Some futures represent a single operation and are explicitly marked as ready by calling the 'done' or 'fail' methods. These are called "leaf" futures here, and are returned by the 'new' constructor.
Other futures represent a collection of sub-tasks, and are implicitly marked as ready depending on the readiness of their component futures as required. These are called "convergent" futures here as they converge control and data-flow back into one place. These are the ones returned by the various 'wait_*' and 'need_*' constructors.
It is intended that library functions that perform asynchronous operations would use future objects to represent outstanding operations, and allow their calling programs to control or wait for these operations to complete. The implementation and the user of such an interface would typically make use of different methods on the class. The methods below are documented in two sections; those of interest to each side of the interface.
It should be noted however, that this module does not in any way provide an actual mechanism for performing this asynchronous activity; it merely provides a way to create objects that can be used for control and data flow around those operations. It allows such code to be written in a neater, forward-reading manner, and simplifies many common patterns that are often involved in such situations.
See also Future::Utils which contains useful loop-constructing functions, to run a future-returning function repeatedly in a loop.
- Sources inherited from project devel:languages:perl
- Devel package for openSUSE:Factory
- Links to openSUSE:Factory / perl-Future
- Download package
-
Checkout Package
osc -A https://api.opensuse.org checkout home:Tomcat42/perl-Future && cd $_
- Create Badge
Source Files
Filename | Size | Changed |
---|---|---|
Future-0.44.tar.gz | 0000094561 92.3 KB | |
_link | 0000000124 124 Bytes | |
cpanspec.yml | 0000000547 547 Bytes | |
perl-Future.changes | 0000011282 11 KB | |
perl-Future.spec | 0000003694 3.61 KB |
Revision 28 (latest revision is 40)
- updated to 0.44 see /usr/share/doc/packages/perl-Future/Changes 0.44 2020-03-25 [CHANGES] * Added ->result; use that in unit tests and docs where appropriate * Slight performance boost in internals by direct field access rather than accessor methods * Document ->await properly; make it wait until ready * Discourage ->block_until_ready
Comments 0