Publication | Open Access
Call graph construction in object-oriented languages
294
Citations
42
References
1997
Year
Unknown Venue
EngineeringCall GraphsCompiler TechnologyObject-oriented ModelingSoftware EngineeringSoftware AnalysisFormal VerificationInterprocedural AnalysesLanguage ConstructGraph ConstructionCompilersDynamic CompilationCompiler SupportLinguisticsComputer EngineeringComputer ScienceOptimizing CompilerStatic Program AnalysisSoftware DesignGraph TheoryProgram AnalysisAutomated ReasoningSoftware TestingFormal MethodsObject-oriented ProgrammingParallel ProgrammingCall Graph ConstructionSystem Software
Interprocedural analyses enable optimizing compilers to more precisely model the effects of non-inlined procedure calls, potentially resulting in substantial increases in application performance. Applying interprocedural analysis to programs written in object-oriented or functional languages is complicated by the difficulty of constructing an accurate program call graph. This paper presents a parameterized algorithmic framework for call graph construction in the presence of message sends and/or first class functions. We use this framework to describe and to implement a number of well-known and new algorithms. We then empirically assess these algorithms by applying them to a suite of medium-sized programs written in Cecil and Java, reporting on the relative cost of the analyses, the relative precision of the constructed call graphs, and the impact of this precision on the effectiveness of a number of interprocedural optimizations.
| Year | Citations | |
|---|---|---|
Page 1
Page 1