Abstract
Developers often need to search for appropriate APIs for their programming tasks. Although most libraries have API reference documentation, it is not easy to find appropriate APIs due to the lexical gap and knowledge gap between the natural language description of the programming task and the API description in API documentation. Here, the lexical gap refers to the fact that the same semantic meaning can be expressed by different words, and the knowledge gap refers to the fact that API documentation mainly describes API functionality and structure but lacks other types of information like concepts and purposes, which are usually the key information in the task description. In this paper, we propose an API recommendation approach named BIKER (Bi-Information source based KnowledgE Recommendation) to tackle these two gaps. To bridge the lexical gap, BIKER uses word embedding technique to calculate the similarity score between two text descriptions. Inspired by our survey findings that developers incorporate Stack Overflow posts and API documentation for bridging the knowledge gap, BIKER leverages Stack Overflow posts to extract candidate APIs for a program task, and ranks candidate APIs by considering the query's similarity with both Stack Overflow posts and API documentation. It also summarizes supplementary information (e.g., API description, code examples in Stack Overflow posts) for each API to help developers select the APIs that are most relevant to their tasks. Our evaluation with 413 API-related questions confirms the effectiveness of BIKER for both class- and method-level API recommendation, compared with state-of-the-art baselines. Our user study with 28 Java developers further demonstrates the practicality of BIKER for API search.
| Original language | English |
|---|---|
| Title of host publication | ASE'18 - Proceedings of the 33rd ACM/IEEE International Conference on Automated Software Engineering |
| Subtitle of host publication | September 3–7, 2018 Montpellier, France |
| Editors | Christian Kastner, Gordon Fraser |
| Place of Publication | New York NY USA |
| Publisher | Association for Computing Machinery (ACM) |
| Pages | 293-304 |
| Number of pages | 12 |
| ISBN (Electronic) | 9781450359375 |
| DOIs | |
| Publication status | Published - 2018 |
| Event | Automated Software Engineering Conference 2018 - Corum Conference Center, Montpellier, France Duration: 3 Sept 2018 → 7 Sept 2018 Conference number: 33rd http://www.ase2018.com/ (Conference website) https://dl.acm.org/doi/proceedings/10.1145/3238147 (Proceedings) |
Conference
| Conference | Automated Software Engineering Conference 2018 |
|---|---|
| Abbreviated title | ASE 2018 |
| Country/Territory | France |
| City | Montpellier |
| Period | 3/09/18 → 7/09/18 |
| Internet address |
|
Keywords
- API documentation
- API recommendation
- Stack overflow
- Word embedding