CAF  0.17.3

A trivial example program.

#include <string>
#include <iostream>
#include "caf/all.hpp"
using std::endl;
using std::string;
using namespace caf;
behavior mirror(event_based_actor* self) {
// return the (initial) actor behavior
return {
// a handler for messages containing a single string
// that replies with a string
[=](const string& what) -> string {
// prints "Hello World!" via aout (thread-safe cout wrapper)
aout(self) << what << endl;
// reply "!dlroW olleH"
return string(what.rbegin(), what.rend());
void hello_world(event_based_actor* self, const actor& buddy) {
// send "Hello World!" to our buddy ...
self->request(buddy, std::chrono::seconds(10), "Hello World!").then(
// ... wait up to 10s for a response ...
[=](const string& what) {
// ... and print it
aout(self) << what << endl;
void caf_main(actor_system& system) {
// create a new actor that calls 'mirror()'
auto mirror_actor = system.spawn(mirror);
// create another actor that calls 'hello_world(mirror_actor)';
system.spawn(hello_world, mirror_actor);
// system will wait until both actors are destroyed before leaving main
// creates a main function for us that calls our caf_main
Describes the behavior of an actor, i.e., provides a message handler and an optional timeout.
Definition: behavior.hpp:52
Identifies an untyped actor.
Definition: actor.hpp:55
A cooperatively scheduled, event-based actor implementation.
Definition: event_based_actor.hpp:61
Actor environment including scheduler, registry, and optional components such as a middleman.
Definition: actor_system.hpp:125
Definition: abstract_actor.hpp:43
CAF_CORE_EXPORT actor_ostream aout(local_actor *self)
Convenience factory function for creating an actor output stream.
infer_handle_from_class_t< C > spawn(Ts &&... xs)
Returns a new actor of type C using xs... as constructor arguments.
Definition: actor_system.hpp:311