Reference Capabilities for Concurrency Control
2016 (English)In: ECOOP 2016 — Object-Oriented Programming, 2016Conference paper (Refereed)
The proliferation of shared mutable state in object-oriented programming complicates software development as two seemingly unrelated operations may interact via an alias and produce unexpected results. In concurrent programming this manifests itself as data-races.
Concurrent object-oriented programming suffers from the fact that code that warrants synchronisation cannot easily be distinguished from code that does not. The burden is placed solely on the programmer to reason about alias freedom, sharing across threads and side-effects to deduce where and when to apply concurrency control, without inadvertently blocking parallelism.
This paper presents a reference capability approach to concurrent and parallel object-oriented programming where all uses of aliases are guaranteed to be data-race free. Locations' static types describe their possible sharing. Type information can express non-interfering deterministic parallelism without dynamic concurrency control, thread-locality, lock-based schemes, and guarded-by relations giving multi-object atomicity to nested data structures. Unification of capabilities and traits allows trait-reuse across multiple concurrency scenarios with minimal code duplication. The resulting system brings together features from a wide range of prior work in a unified way.
Place, publisher, year, edition, pages
IdentifiersURN: urn:nbn:se:uu:diva-287587OAI: oai:DiVA.org:uu-287587DiVA: diva2:922959
ECOOP 2016, July 17–22, Rome, Italy
FunderSwedish Research CouncilEU, FP7, Seventh Framework Programme