JAVA']JAVA & LAMBDA: A FEATHERWEIGHT STORY

被引:4
|
作者
Bettini, Lorenzo [1 ]
Bono, Viviana [2 ]
Dezani-Ciancaglini, Mariangiola [2 ]
Giannini, Paola [3 ]
Venneri, Betti [1 ]
机构
[1] Univ Firenze, Dipartimento Stat, Informat, Applicaz, Florence, Italy
[2] Univ Torino, Dipartimento Informat, Turin, Italy
[3] Univ Piemonte Orientale, Dipartimento Sci & Innovaz Tecnol, Vercelli, Italy
基金
欧盟地平线“2020”;
关键词
OBJECT;
D O I
10.23638/LMCS-14(3:17)2018
中图分类号
TP301 [理论、方法];
学科分类号
081202 ;
摘要
We present FJ &, a new core calculus that extends Featherweight Java (FJ) with interfaces, supporting multiple inheritance in a restricted form, lambda-expressions, and intersection types. Our main goal is to formalise how lambdas and intersection types are grafted on Java 8, by studying their properties in a formal setting. We show how intersection types play a significant role in several cases, in particular in the typecast of a lambda-expression and in the typing of conditional expressions. We also embody interface default methods in FJ &, since they increase the dynamism of lambda-expressions, by allowing these methods to be called on lambda-expressions. The crucial point in Java 8 and in our calculus is that lambda-expressions can have various types according to the context requirements (target types): indeed, Java code does not compile when lambda-expressions come without target types. In particular, in the operational semantics we must record target types by decorating lambda-expressions, otherwise they would be lost in the runtime expressions. We prove the subject reduction property and progress for the resulting calculus, and we give a type inference algorithm that returns the type of a given program if it is well typed. The design of FJ & has been driven by the aim of making it a subset of Java 8, while preserving the elegance and compactness of FJ. Indeed, FJ & programs are typed and behave the same as Java programs.
引用
收藏
页数:24
相关论文
共 50 条
  • [1] Featherweight Wrap Java']Java
    Bettini, Lorenzo
    Capecchi, Sara
    Giachino, Elena
    [J]. APPLIED COMPUTING 2007, VOL 1 AND 2, 2007, : 1094 - +
  • [2] Lightweight confinement for Featherweight Java']Java
    Zhao, T
    Palsberg, J
    Vitek, J
    [J]. ACM SIGPLAN NOTICES, 2003, 38 (11) : 135 - 148
  • [3] Featherweight Java']Java - A minimal core calculus for Java']Java and GJ
    Igarashi, A
    Pierce, B
    Wadler, P
    [J]. ACM SIGPLAN NOTICES, 1999, 34 (10) : 132 - 146
  • [4] SFJ: An Implementation of Semantic Featherweight Java']Java
    Usov, Artem
    Dardha, Ornela
    [J]. COORDINATION MODELS AND LANGUAGES, COORDINATION 2020, 2020, 12134 : 153 - 168
  • [5] A Generic Type System for Featherweight Java']Java
    Schoepp, Ulrich
    Xu, Chuangjie
    [J]. PROCEEDINGS OF THE 23RD ACM INTERNATIONAL WORKSHOP ON FORMAL TECHNIQUES FOR JAVA-LIKE PROGRAMS (FTFJP '21), 2021, : 9 - 15
  • [6] Featherweight Java']Java: A minimal core calculus for Java']Java and GJ
    Igarashi, A
    Pierce, BC
    Wadler, P
    [J]. ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2001, 23 (03): : 396 - 450
  • [7] Safe Commits for Transactional Featherweight Java']Java
    Thi Mai Thuong Tran
    Steffen, Martin
    [J]. INTEGRATED FORMAL METHODS, 2010, 6396 : 290 - 304
  • [8] Featherweight Java']Java with dynamic and static overloading
    Bettini, Lorenzo
    Capecchi, Sara
    Venneri, Betti
    [J]. SCIENCE OF COMPUTER PROGRAMMING, 2009, 74 (5-6) : 261 - 278
  • [9] Semantic Types and Approximation for Featherweight Java']Java
    Rowe, Reuben N. S.
    van Bakel, S. J.
    [J]. THEORETICAL COMPUTER SCIENCE, 2014, 517 : 34 - 74
  • [10] FeatherTrait: A modest extension of Featherweight Java']Java
    Liquori, Luigi
    Spiwack, Arnaud
    [J]. ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2008, 30 (02):