Reference Capabilities for Flexible Memory Management

Proc. ACM Program. Lang. | , Vol 7(OOPSLA2)

Preprint

Verona is a concurrent object-oriented programming language that organises all the objects in a program
into a forest of isolated regions. Memory is managed locally for each region, so programmers can control
a program’s memory use by adjusting objects’ partition into regions, and by setting each region’s memory
management strategy. A thread can only mutate (allocate, deallocate) objects within one active region — its
“window of mutability”. Memory management costs are localised to the active region, ensuring overheads
can be predicted and controlled. Moving the mutability window between regions is explicit, so code can be
executed wherever it is required, yet programs remain in control of memory use. An ownership type system
based on reference capabilities enforces region isolation, controlling aliasing within and between regions,
yet supporting objects moving between regions and threads. Data accesses never need expensive atomic
operations, and are always thread-safe.