Treffer: Detecting Uninitialized Variables in C++ with the Clang Static Analyzer.

Title:
Detecting Uninitialized Variables in C++ with the Clang Static Analyzer.
Source:
Acta Cybernetica; 2022, Vol. 25 Issue 4, p923-940, 18p
Database:
Complementary Index

Weitere Informationen

Uninitialized variables have been a source of errors since the beginning of software engineering. Some programming languages (e.g. Java and Python) will automatically zero-initialize such variables, but others, like C and C++, leave their state undefined. While laying aside initialization in C and C++ might be a performance advantage if an initial value cannot be supplied, working with variables is an undefined behaviour, and is a common source of instabilities and crashes. To avoid such errors, whenever meaningful initialization is possible, it should be applied. Tools for detecting these errors run time have existed for decades, but those require the problematic code to be executed. Since in many cases, the number of possible execution paths is combinatoric, static analysis techniques emerged as an alternative to achieve greater code coverage. In this paper, we overview the technique for detecting uninitialized C++ variables using the Clang Static Analyzer, and describe various heuristics to guess whether a specific variable was left in an undefined state intentionally. We implemented and published a prototype tool based on our idea and successfully tested it on large open-source projects. This so-called "checker" has been a part of LLVM/Clang releases since 9.0.0 under the name optin.cplusplus.UninitializedObject. [ABSTRACT FROM AUTHOR]

Copyright of Acta Cybernetica is the property of University of Szeged, Institute of Informatics and its content may not be copied or emailed to multiple sites without the copyright holder's express written permission. Additionally, content may not be used with any artificial intelligence tools or machine learning technologies. However, users may print, download, or email articles for individual use. This abstract may be abridged. No warranty is given about the accuracy of the copy. Users should refer to the original published version of the material for the full abstract. (Copyright applies to all Abstracts.)