Simons, A.J.H. orcid.org/0000-0002-5925-7148 (1998) Borrow, copy or steal?: loans and larceny in the orthodox canonical form. In: OOPSLA '98: Proceedings of the 13th ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications. OOPSLA98: Conference on Object Oriented Programming Systems Languages and Applications, 18-22 Oct 1998, Vancouver, British Columbia, Canada. ACM , pp. 65-83. ISBN 1581130058
Abstract
Dynamic memory management in C++ is complex, especially across the boundaries of library abstract data types. C++ libraries designed in the orthodox canonical form (OCF) alleviate some of the problems by ensuring that classes which manage any kind of heap structures faithfully copy and delete these. However, in certain common circumstances, OCF heap structures are wastefully copied multiple times. General reference counting is not an option in OCF, since a shared body violates the intended value semantics; although a copy-on-write policy can be made to work with borrowed heap structures. A simpler ownership policy, based on larceny, allows low-level memory manager objects to steal heap structures from temporary variables, in properly isolated circumstances. Various strategies for regulating theft are presented, ranging from pilfer-constructors to locks on heap data. Larceny has similarities with other transfer of ownership patterns, but is more a core implementation technique designed to improve the efficiency and effectiveness of OCF-conformant libraries.
Metadata
Item Type: | Proceedings Paper |
---|---|
Authors/Creators: |
|
Copyright, Publisher and Additional Information: | © 1998 ACM |
Dates: |
|
Institution: | The University of Sheffield |
Academic Units: | The University of Sheffield > Faculty of Engineering (Sheffield) > Department of Computer Science (Sheffield) |
Depositing User: | Symplectic Sheffield |
Date Deposited: | 29 Jun 2023 12:13 |
Last Modified: | 29 Jun 2023 12:13 |
Published Version: | http://dx.doi.org/10.1145/286936.286948 |
Status: | Published |
Publisher: | ACM |
Refereed: | Yes |
Identification Number: | 10.1145/286936.286948 |
Open Archives Initiative ID (OAI ID): | oai:eprints.whiterose.ac.uk:201062 |