Go to file
2014-01-28 19:03:04 +01:00
build rename simple_stack_allocator into standard_stack_allocator 2014-01-27 20:09:27 +01:00
doc add missingtemplate arg in coroutine_fn typedef 2014-01-28 18:52:26 +01:00
example allocate on stack 2014-01-25 23:41:06 +01:00
include/boost/coroutine fix Windows - typos 2014-01-28 19:03:04 +01:00
performance rename simple_stack_allocator into standard_stack_allocator 2014-01-27 20:09:27 +01:00
src fix copy-ctor and assignment-operator for coroutine_context 2014-01-28 17:58:53 +01:00
test fix copy-ctor and assignment-operator for coroutine_context 2014-01-28 17:58:53 +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.