An empirical study of static program slice size

作者:Binkley David*; Gold Nicolas; Harman Mark
来源:ACM Transactions on Software Engineering and Methodology, 2007, 16(2): 8.
DOI:10.1145/1217295.1217297

摘要

This article presents results from a study of all shoes from 43 programs, ranging up to 136,000 lines of code in size. The study investigates the effect of five aspects that affect slice size. Three slicing algorithms are used to study two algorithmic aspects: calling-context treatment, and slice granularity. The remaining three aspects affect the upstream dependencies considered by the slicer. These include collapsing structure fields, removal of dead code, and the influence of points-to analysis. The results show that for the most precise slicer, the average slice contains just under one-third of the program. Furthermore, ignoring calling context causes a 50% increase in slice size, and while (coarse-grained) function-level slices are 33% larger than corresponding statement-level slices, they may be useful predictors of the (finer-grained) statement-level slice size. Finally,, upstream analyses have an order of magnitude less influence on slice size.

  • 出版日期2007