Large-scale characterization of Java']Java streams

被引:0
|
作者
Rosales, Eduardo [1 ,2 ]
Basso, Matteo [1 ]
Rosa, Andrea [1 ]
Binder, Walter [1 ]
机构
[1] Univ Svizzera Italiana, Fac Informat, Lugano, Switzerland
[2] Univ Svizzera Italiana, Fac Informat, CH-6900 Lugano, Switzerland
来源
SOFTWARE-PRACTICE & EXPERIENCE | 2023年 / 53卷 / 09期
关键词
code repositories; dynamic program analysis; empirical studies; GitHub; !text type='Java']Java[!/text] streams; !text type='Java']Java[!/text] virtual machine;
D O I
10.1002/spe.3213
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Java streams are receiving the attention of developers targeting the Java virtual machine (JVM) as they ease the development of data-processing logic, while also favoring code extensibility and maintainability through a concise and declarative style based on functional programming. Recent studies aim to shedding light on how Java developers use streams. However, they consider only small sets of applications and mainly apply manual code inspection and static analysis techniques. As a result, the large-scale dynamic analysis of stream processing remains an open research question. In this article, we present the first large-scale empirical study on the use of streams in Java code exercised via unit tests. We present stream-analyzer, a novel dynamic program analysis (DPA) that collects runtime information and key metrics, which enable a fine-grained characterization of sequential and parallel stream processing. We use a fully automatic approach to massively apply our DPA for the analysis of open-source software projects hosted on GitHub. Our findings advance the understanding of the use of Java streams. Both the scale of our analysis and the profiling of dynamic information enable us to confirm with more confidence the outcome highlighted at a smaller scale by related work. Moreover, our study reports the popularity of many features of the Stream API and highlights multiple findings about runtime characteristics unique to streams, while also revealing inefficient stream processing and stream misuses. Finally, we present implications of our findings for developers of the Stream API, tool builders and researchers, and educators.
引用
收藏
页码:1763 / 1792
页数:30
相关论文
共 50 条
  • [41] A Java']Java Program for LRE-Based Real-Time qPCR that Enables Large-Scale Absolute Quantification
    Rutledge, Robert G.
    [J]. PLOS ONE, 2011, 6 (03):
  • [42] Infinite streams in Java
    Gruntz, Dominik
    [J]. ACM Int. Conf. Proc. Ser., (182-187):
  • [43] A Java graphical user interface for large-scale scientific computations in distributed systems
    Shen, X.
    Thiruvathukal, G.
    Liao, W.
    Choudhary, A.
    Singh, A.
    [J]. Proceedings - 4th International Conference/Exhibition on High Performance Computing in the Asia-Pacific Region, HPC-Asia 2000, 2000, 1 : 478 - 484
  • [44] Applying static analysis to large-scale, multi-threaded Java programs
    Swiss Federal Institute of Technology, Institute of Computer Systems, ETH Zentrum, RZ H, Zürich
    CH-8092, Switzerland
    [J]. Proc Aust Software Eng Conf ASWEC, (68-75):
  • [45] Enhancing Java']Java Streams API with PowerList Computation
    Niculescu, Virginia
    Bufnea, Darius
    Sterca, Adrian
    [J]. 2020 IEEE 34TH INTERNATIONAL PARALLEL AND DISTRIBUTED PROCESSING SYMPOSIUM WORKSHOPS (IPDPSW 2020), 2020, : 375 - 384
  • [46] Practically Tunable Static Analysis Framework for Large-Scale Java']JavaScript Applications
    Ko, Yoonseok
    Lee, Hongki
    Dolby, Julian
    Ryu, Sukyoung
    [J]. 2015 30TH IEEE/ACM INTERNATIONAL CONFERENCE ON AUTOMATED SOFTWARE ENGINEERING (ASE), 2015, : 541 - 551
  • [47] A large-scale empirical study on Java library migrations: Prevalence, trends, and rationales
    He, Hao
    He, Runzhi
    Gu, Haiqiao
    Zhou, Minghui
    [J]. ESEC/FSE 2021 - Proceedings of the 29th ACM Joint Meeting European Software Engineering Conference and Symposium on the Foundations of Software Engineering, 2021, : 478 - 490
  • [48] Research on the Large-scale E-commerce Platform Development Mode Based on Oracle Database and Java']Java Programming Language
    Wang, Meiyan
    [J]. 2015 3RD INTERNATIONAL CONFERENCE ON ADVANCES IN SOCIAL SCIENCE, HUMANITIES, AND MANAGEMENT, ASSHM 2015, 2015, : 1082 - 1091
  • [49] An Empirical Study on the Use and Misuse of Java']Java 8 Streams
    Khatchadourian, Raffi
    Tang, Yiming
    Bagherzadeh, Mehdi
    Ray, Baishakhi
    [J]. FUNDAMENTAL APPROACHES TO SOFTWARE ENGINEERING (FASE 2020), 2020, 12076 : 97 - 118
  • [50] Large Java']Java Arrays and Their Applications
    Wendykier, Piotr
    Borucki, Bartosz
    Nowinski, Krzysztof S.
    [J]. PROCEEDINGS OF THE 2015 INTERNATIONAL CONFERENCE ON HIGH PERFORMANCE COMPUTING & SIMULATION (HPCS 2015), 2015, : 460 - 467