Published November 30, 2020 | Version v1
Conference paper

Behavioural Types for Memory and Method Safety in a Core Object-Oriented Language

Description

We present a type-based analysis ensuring memory safety and object protocol completion in the Java-like language Mungo. Objects are annotated with usages, typestates-like specifications of the admissible sequences of method calls. The analysis entwines usage checking, controlling the order in which methods are called, with a static check determining whether references may contain null values. It prevents null pointer dereferencing in a typestate-aware manner and memory leaks and ensures that the intended usage protocol of every object is respected and completed. The type system admits an algorithm that infers the most general usage with respect to a simulation preorder. The type system is implemented in the form of a type checker and a usage inference tool.

Abstract

International audience

Additional details

Identifiers

URL
https://hal.inria.fr/hal-03102375
URN
urn:oai:HAL:hal-03102375v1

Origin repository

Origin repository
UNICA