Misplaced Pages

Locks-and-keys (computing)

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

Locks-and-keys is a solution to dangling pointers in computer programming languages.

The locks-and-keys approach represents pointers as ordered pairs (key, address) where the key is an integer value. Heap-dynamic variables are represented as the storage for the variable plus a cell for an integer lock value. When a variable is allocated, a lock value is created and placed both into the variable's cell and into the pointer's key cell. Every access to the pointer compares these two values, and access is allowed only if the values match.

When a variable is deallocated, the key of its pointer is modified to hold a value different from the variable's cell. From then on, any attempt to dereference the pointer can be flagged as an error. Since copying a pointer also copies its cell value, changing the key of the ordered pair safely disables all copies of the pointer.

See also

References

  1. Sebesta, Robert (2012). Concepts of Programming Languages (10th ed.). Pearson. p. 298. ISBN 978-0-13-139531-2.


Stub icon

This programming-language-related article is a stub. You can help Misplaced Pages by expanding it.

Categories:
Locks-and-keys (computing) Add topic