Home
Scholarly Works
An Efficient Implementation of Guard-Based...
Preprint

An Efficient Implementation of Guard-Based Synchronization for an Object-Oriented Programming Language

Abstract

In the shared variable model of concurrency, guarded atomic actions restrict the possible interference between processes by regions of atomic execution. The guard specifies the condition for entering an atomic region. That is a convenient model for the specification and verification of concurrent programs, but has eschewed efficient execution so far. This article shows how guarded atomic actions, when attached to objects, can be implemented highly efficiently using a combination of coroutines, operating-system worker threads, and dedicated management of object queues and stacks. The efficiency of an experimental language, Lime, is shown to compare favourably with that of C/Pthreads, Go, Erlang, Java, and Haskell on synthetic benchmarks.

Authors

Yao S; Sekerinski E

Publication date

May 27, 2025

DOI

10.48550/arxiv.2505.20850

Preprint server

arXiv
View published work (Non-McMaster Users)

Contact the Experts team