Automatic extraction of heap reference properties in object-oriented programs
Author(s)
Demsky, Brian; Rinard, Martin C.
DownloadC7A6BCBBd01.pdf (286.5Kb)
OPEN_ACCESS_POLICY
Open Access Policy
Creative Commons Attribution-Noncommercial-Share Alike
Terms of use
Metadata
Show full item recordAbstract
We present a new technique for helping developers understand heap referencing properties of object-oriented programs
and how the actions of the program affect these properties. Our dynamic analysis uses the aliasing properties of objects to synthesize
a set of roles; each role represents an abstract object state intended to be of interest to the developer. We allow the developer to
customize the analysis to explore the object states and behavior of the program at multiple different and potentially complementary
levels of abstraction. The analysis uses roles as the basis for three abstractions: role transition diagrams, which present the observed
transitions between roles and the methods responsible for the transitions; role relationship diagrams, which present the observed
referencing relationships between objects playing different roles; and enhanced method interfaces, which present the observed roles
of method parameters. Together, these abstractions provide useful information about important object and data structure properties
and how the actions of the program affect these properties. We have implemented the role analysis and have used this implementation
to explore the behavior of several Java programs. Our experience indicates that, when combined with a powerful graphical user
interface, roles are a useful abstraction for helping developers explore and understand the behavior of object-oriented programs.
Date issued
2009-05Department
Massachusetts Institute of Technology. Department of Electrical Engineering and Computer ScienceJournal
IEEE Transactions on Software Engineering
Publisher
Institute of Electrical and Electronics Engineers
Citation
Automatic Extraction of Heap Reference Properties in Object-Oriented Programs
Demsky, B.; Rinard, M.;
Software Engineering, IEEE Transactions on
Volume 35, Issue 3, May-June 2009 Page(s):305 - 324
Version: Author's final manuscript
ISSN
0098-5589