Abstract
The acronym CaRuD represents an interface specification and an algorithm for the management of memory shared by concurrent processes. The memory cells form a directed acyclic graph. This graph is only modified by adding a new node with a list of reachable children, and by removing unreachable nodes. If memory is not full, the algorithm ensures wait-free redistribution of free nodes. It uses atomic counters for reference counting and consensus variables to ensure exclusive access. Performance is enhanced by using nondeterminacy guided by insecure knowledge. Experiments indicate that the algorithm is very suitable for multiprocessing.
Original language | English |
---|---|
Pages (from-to) | 31-39 |
Journal | Distributed Computing |
Volume | 14 |
Issue number | 1 |
DOIs | |
Publication status | Published - 2001 |