Reasoning between Programming Languages and Architectures - TEL - Thèses en ligne Access content directly
Habilitation À Diriger Des Recherches Year : 2014

Reasoning between Programming Languages and Architectures

Abstract

The amazing complexity of today's programming calls for a new engineering approach to build robust systems. Recent progress in formal methods and mechanised proof assistants have made it possible to apply mathematically rigorous methods to the specification, testing and verification of ambitious projects. Nevertheless, despite some remarkable successes, working with full-scale, realistic, system interfaces is still in its infancy and novel tools and reasoning techniques are needed to support a major change in the engineering practice. In this spirit, each chapter of this mémoire d'habilitation proposes a solution to a problem arising from programming experience: Chapter 1 points out how shared memory is a subtle model of computation, and shows how to rigorously build sound abstractions of the relaxed memory exhibited by mainstream programming languages and architectures; Chapter 2 illustrates how hard concurrency problems, as hunting concurrency compiler bugs, can be made tractable via semantic techniques that enable thread-wise reasoning; Chapter 3 discusses the difficulties of formalising language definitions, introduces the Ott tool for the working semanticist and reports on five years of user feedback; Chapter 4 explores the design space to integrate typed and untyped code in scripting languages and presents a sweet spot where programmers benefit from the best of the two worlds. Each chapter ends with some open research directions that, in my opinion, constitute necessary and significant steps towards making modern systems easier to program, analyse and test.
Fichier principal
Vignette du fichier
main.pdf (735.38 Ko) Télécharger le fichier
Loading...

Dates and versions

tel-01110117 , version 1 (27-01-2015)

Identifiers

  • HAL Id : tel-01110117 , version 1

Cite

Francesco Zappa Nardelli. Reasoning between Programming Languages and Architectures. Computer Science [cs]. ENS Paris - Ecole Normale Supérieure de Paris, 2014. ⟨tel-01110117⟩
287 View
172 Download

Share

Gmail Facebook X LinkedIn More