Handles: Behavior-Propagating First Class References For Dynamically-Typed Languages - Archive ouverte HAL Access content directly
Journal Articles Science of Computer Programming Year : 2015

Handles: Behavior-Propagating First Class References For Dynamically-Typed Languages

(1) , (1) , (1) , (1)
1

Abstract

Controlling object graphs and giving specific semantics to references (such as read-only, ownership, scoped sharing) have been the focus of a large body of research in the context of static type systems. Controlling references to single objects and to graphs of objects is essential to build more secure systems, but is notoriously hard to achieve in the absence of static type systems. In this article we embrace this challenge by proposing a solution to the following question: What is an underlying mechanism that can support the definition of properties (such as revocable, read-only, lent) at the reference level in the absence of a static type system? We present handles: first-class references that propagate behavioral change dynamically to the object subgraph during program execution. In this article we describe handles and show how handles support the implementation of read-only references and revocable references. Handles have been fully implemented by modifying an existing virtual machine and we report their costs.
Fichier principal
Vignette du fichier
2015Handles.pdf (506.66 Ko) Télécharger le fichier
Origin : Files produced by the author(s)

Dates and versions

hal-01060537 , version 1 (03-09-2014)
hal-01060537 , version 2 (31-12-2015)

Identifiers

Cite

Jean-Baptiste Arnaud, Stéphane Ducasse, Marcus Denker, Camille Teruel. Handles: Behavior-Propagating First Class References For Dynamically-Typed Languages. Science of Computer Programming, 2015, Science of Computer Programming, 98 (3), pp. 318-338. ⟨10.1016/j.scico.2014.07.011⟩. ⟨hal-01060537v2⟩
430 View
170 Download

Altmetric

Share

Gmail Facebook Twitter LinkedIn More