The async package
This package provides a higher-level interface over threads, in which an Async a is a concurrent thread that will eventually deliver a value of type a. The package provides ways to create Async computations, wait for their results, and cancel them.
Using Async is safer than using threads in two ways:
When waiting for a thread to return a result, if the thread dies with an exception then the caller must either re-throw the exception (wait) or handle it (waitCatch); the exception cannot be ignored.
The API makes it possible to build a tree of threads that are automatically killed when their parent dies (see withAsync).
Changes in 188.8.131.52:
Added a Functor instance for Async
Added asyncBound, asyncOn, asyncWithUnmask, asyncOnWithUnmask, withAsyncBound, withAsyncOn, withAsyncWithUnmask, withAsyncOnWithUnmask.
Added Concurrently (with Applicative and Alternative instances)
|Versions||1.0, 1.1, 1.2, 1.3, 1.4, 184.108.40.206, 220.127.116.11, 18.104.22.168, 22.214.171.124, 126.96.36.199, 188.8.131.52, 184.108.40.206, 220.127.116.11, 2.0.2|
|Change log||None available|
|Dependencies||base (>=4.3 && <4.6), stm (>=2.2 && <2.4)|
|Copyright||(c) Simon Marlow 2012|
|Maintainer||Simon Marlow <firstname.lastname@example.org>|
|Source repository||head: git clone https://github.com/simonmar/async.git|
|Uploaded||Tue Jul 3 13:30:20 UTC 2012 by SimonMarlow|
|Distributions||Debian:18.104.22.168, Fedora:22.214.171.124, FreeBSD:126.96.36.199, LTSHaskell:2.0.2, NixOS:2.0.2, Stackage:2.0.2|
|Downloads||85278 total (904 in last 30 days)|
|Status||Docs uploaded by user|
Build status unknown [no reports yet]
For package maintainers and hackage trustees