A static analyzer for finding dynamic programming errors

There are important classes of programming errors that are hard to diagnose, both manually and automatically, because they involve a program's dynamic behavior. This article describes a compile‐time analyzer that detects these dynamic errors in large, real‐world programs. The analyzer traces ex...

Full description

Saved in:
Bibliographic Details
Published inSoftware, practice & experience Vol. 30; no. 7; pp. 775 - 802
Main Authors Bush, William R., Pincus, Jonathan D., Sielaff, David J.
Format Journal Article
LanguageEnglish
Published Chichester, UK John Wiley & Sons, Ltd 01.06.2000
Subjects
Online AccessGet full text

Cover

Loading…
More Information
Summary:There are important classes of programming errors that are hard to diagnose, both manually and automatically, because they involve a program's dynamic behavior. This article describes a compile‐time analyzer that detects these dynamic errors in large, real‐world programs. The analyzer traces execution paths through the source code, modeling memory and reporting inconsistencies. In addition to avoiding false paths through the program, this approach provides valuable contextual information to the programmer who needs to understand and repair the defects. Automatically‐created models, ing the behavior of individual functions, allow inter‐procedural defects to be detected efficiently. A product built on these techniques has been used effectively on several large commercial programs. Copyright © 2000 John Wiley & Sons, Ltd.
Bibliography:istex:7A4211C4DFD3CD26D8143E5B8E48C7D07E2B92A5
ark:/67375/WNG-T6GCKKN4-0
ArticleID:SPE309
ObjectType-Article-2
SourceType-Scholarly Journals-1
ObjectType-Feature-1
content type line 23
ISSN:0038-0644
1097-024X
DOI:10.1002/(SICI)1097-024X(200006)30:7<775::AID-SPE309>3.0.CO;2-H