Integrative levels of program comprehension describe the evolution of our knowledge about a program from low-level program elements through successive and higher orders of knowledge integration. In this paper, we motivate, define, and illustrate integrative levels as a technique to organize the knowledge that we acquire in the course of program maintenance. We differentiate between understanding in extension and understanding in intension. We define five intensional integrative levels of program comprehension, the element level, the percept level, the concept level, the subject level, and the domain level. The intensional units that make up these levels emerge and evolve in an iterative comprehension process that is active at each level. The iterations of this process comprise the four phases of lower level unit organization, unit integration, upper level unit organization, and unit validation. We demonstrate integrative levels of program comprehension using the object-oriented testin...
Reinhard Schauer, Rudolf K. Keller