On the value of static analysis for fault detection in software
Top Cited Papers
- 8 May 2006
- journal article
- Published by Institute of Electrical and Electronics Engineers (IEEE) in IEEE Transactions on Software Engineering
- Vol. 32 (4) , 240-253
- https://doi.org/10.1109/tse.2006.38
Abstract
No single software fault-detection technique is capable of addressing all fault-detection concerns. Similarly to software reviews and testing, static analysis tools (or automated static analysis) can be used to remove defects prior to release of a software product. To determine to what extent automated static analysis can help in the economic production of a high-quality product, we have analyzed static analysis faults and test and customer-reported failures for three large-scale industrial software systems developed at Nortel Networks. The data indicate that automated static analysis is an affordable means of software fault detection. Using the orthogonal defect classification scheme, we found that automated static analysis is effective at identifying assignment and checking faults, allowing the later software production phases to focus on more complex, functional, and algorithmic faults. A majority of the defects found by automated static analysis appear to be produced by a few key types of programmer errors and some of these types have the potential to cause security vulnerabilities. Statistical analysis results indicate the number of automated static analysis faults can be effective for identifying problem modules. Our results indicate static analysis tools are complementary to other fault-detection techniques for the economic production of a high-quality software product.Keywords
This publication has 26 references indexed in Scilit:
- Static analysis for securityIEEE Security & Privacy, 2004
- Righting softwareIEEE Software, 2004
- USING CLASSIFICATION TREES FOR SOFTWARE QUALITY MODELS: LESSONS LEARNEDInternational Journal of Software Engineering and Knowledge Engineering, 1999
- Application of neural networks to software quality modeling of a very large telecommunications systemIEEE Transactions on Neural Networks, 1997
- Assessing software review meetings: results of a comparative analysis of two experimental studiesIEEE Transactions on Software Engineering, 1997
- Software defect-removal efficiencyComputer, 1996
- The detection of fault-prone programsIEEE Transactions on Software Engineering, 1992
- An experimental study of fault detection in user requirements documentsACM Transactions on Software Engineering and Methodology, 1992
- Orthogonal defect classification-a concept for in-process measurementsIEEE Transactions on Software Engineering, 1992
- Regression modelling of software quality: empirical investigationInformation and Software Technology, 1990