SEOct 23, 2021

How Do I Refactor This? An Empirical Study on Refactoring Trends and Topics in Stack Overflow

arXiv:2110.12229v177 citations
Originality Synthesis-oriented
AI Analysis

This work addresses the problem of aligning refactoring research with real-world developer practices, though it is incremental as it builds on existing studies by focusing on empirical data from online forums.

The study analyzed refactoring discussions on Stack Overflow to understand developer needs and challenges, identifying five key areas where developers seek assistance, such as Code Optimization and Architecture, to bridge the gap between academic research and practical adoption.

An essential part of software maintenance and evolution, refactoring is performed by developers, regardless of technology or domain, to improve the internal quality of the system, and reduce its technical debt. However, choosing the appropriate refactoring strategy is not always straightforward, resulting in developers seeking assistance. Although research in refactoring is well-established, with several studies altering between the detection of refactoring opportunities and the recommendation of appropriate code changes, little is known about their adoption in practice. Analyzing the perception of developers is critical to understand better what developers consider to be problematic in their code and how they handle it. Additionally, there is a need for bridging the gap between refactoring, as research, and its adoption in practice, by extracting common refactoring intents that are more suitable for what developers face in reality. In this study, we analyze refactoring discussions on Stack Overflow through a series of quantitative and qualitative experiments. Our results show that Stack Overflow is utilized by a diverse set of developers for refactoring assistance for a variety of technologies. Our observations show five areas that developers typically require help with refactoring -- Code Optimization, Tools and IDEs, Architecture and Design Patterns, Unit Testing, and Database. We envision our findings better bridge the support between traditional (or academic) aspects of refactoring and their real-world applicability, including better tool support.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes