World age in Julia: optimizing method dispatch in the presence of eval

Abstract

Dynamic programming languages face semantic and performance challenges in the presence of features, such as eval, that can inject new code into a running program. The Julia programming language introduces the novel concept of world age to insulate optimized code from one of the most disruptive side-effects of eval: changes to the definition of an existing function. This paper provides the first formal semantics of world age in a core calculus named juliette, and shows how world age enables compiler optimizations, such as inlining, in the presence of eval. While Julia also provides programmers with the means to bypass world age, we found that this mechanism is not used extensively: a static analysis of over 4,000 registered Julia packages shows that only 4-9% of packages bypass world age. This suggests that Julia's semantics aligns with programmer expectations.

Document Details

Document Type
Pub Defense Publication
Publication Date
Nov 13, 2020
Source ID
10.1145/3428275

Entities

People

  • Benjamin Chung
  • Jack Gelinas
  • Jameson Nash
  • Jan Vitek
  • Julia Belyakova
  • Ross Tate

Organizations

  • Cornell University
  • Framework Programmes for Research and Technological Development
  • Julia Computing
  • National Science Foundation
  • Northeastern University
  • Office of Naval Research

Tags

Fields of Study

  • Computer science

Readers

  • Computational Linguistics
  • Computer Science.
  • Economics

Technology Areas

  • Microelectronics