The simple actor framework
Go to file
2022-04-11 12:21:18 +03:00
bin add threadsafe_queue 2022-04-11 12:21:18 +03:00
src add threadsafe_queue 2022-04-11 12:21:18 +03:00
subprojects init 2022-04-11 10:23:05 +03:00
tests init 2022-04-11 10:23:05 +03:00
logo.png init 2022-04-11 10:23:05 +03:00
meson.build init 2022-04-11 10:23:05 +03:00
README.md init 2022-04-11 10:23:05 +03:00
run init 2022-04-11 10:23:05 +03:00

actfm's logo The actor model is well described and if you dont know anything about it, you can read about it elsewhere.

This Actor Model behaves as follows:

  • An Actor is a unit of computation. It can accept a message and asynchronously perform some action based on user-specified behaviour.
  • Actors have a “sendbox”, usually an in-memory queue that stores messages sent to that actor.
  • Actors do not access shared state.
  • Actors “own” any state they operate on, so the need for locking mechanisms is reduced*.

Heres how it work:

  • Client code define the type of the message an actor can handle, and the type of the result produced by that actor using template parameters. In other words, the actors are statically typed.
  • There have a simple actor interface. Clients send a message to an actor in two ways: actor.send if they dont expect a response, or actor.expect if a response is required.
  • Actor systems are instantiated with a thread pool onto which work dispatched.
  • Actor systems are instantiated with a scheduler which handle the dispatching of tasks onto the thread pool in a fair manner.