Concepedia

Publication | Open Access

Linearizability: a correctness condition for concurrent objects

3.2K

Citations

37

References

1990

Year

TLDR

Linearizability is a correctness condition for concurrent objects that allows high concurrency while enabling reasoning about them using sequential domain techniques by making each operation appear to occur instantaneously between its invocation and response, thereby providing clear pre‑ and post‑conditions. The paper defines linearizability, compares it to other correctness conditions, and presents a method for proving the correctness of implementations. The authors demonstrate this method for proving correctness of concurrent object implementations. The paper shows how to reason about concurrent objects given they are linearizable.

Abstract

A concurrent object is a data object shared by concurrent processes. Linearizability is a correctness condition for concurrent objects that exploits the semantics of abstract data types. It permits a high degree of concurrency, yet it permits programmers to specify and reason about concurrent objects using known techniques from the sequential domain. Linearizability provides the illusion that each operation applied by concurrent processes takes effect instantaneously at some point between its invocation and its response, implying that the meaning of a concurrent object's operations can be given by pre- and post-conditions. This paper defines linearizability, compares it to other correctness conditions, presents and demonstrates a method for proving the correctness of implementations, and shows how to reason about concurrent objects, given they are linearizable.

References

YearCitations

Page 1