Go to file
2014-02-02 17:06:50 +01:00
build remove pull/push_coroutine_object classes 2014-01-29 16:59:19 +01:00
doc fix documentation: performance of x86_64 2014-01-29 17:27:35 +01:00
example first working draft of symmetric coroutines 2014-02-02 08:14:32 +01:00
include/boost/coroutine pass values per reference to other coroutine (yield_to) 2014-02-02 17:01:44 +01:00
performance use name asymmetric_coroutine in perfromance test 2014-02-02 17:06:50 +01:00
src fix copy-ctor and assignment-operator for coroutine_context 2014-01-28 17:58:53 +01:00
test use asymmetric_coroutine<> in unit-test 2014-02-02 17:03:07 +01:00
.gitattributes Move top-level boost directory over to "devel" (temporarily) 2007-07-31 20:32:15 +00:00
.gitignore modify gitignore file 2014-01-16 20:38:53 +01:00
index.html coroutine: initial commit 2012-11-24 19:42:09 +00:00
README.md sync with olk-repo 2013-12-04 22:26:09 +01:00

boost.coroutine

boost.coroutine provides templates for generalized subroutines which allow multiple entry points for suspending and resuming execution at certain locations. It preserves the local state of execution and allows re-entering subroutines more than once (useful if state must be kept across function calls).

Coroutines can be viewed as a language-level construct providing a special kind of control flow.

In contrast to threads, which are pre-emptive, coroutines switches are cooperative (programmer controls when a switch will happen). The kernel is not involved in the coroutine switches.