Verification of object-oriented programs: A transformational approach

Open Access
Authors
  • K.R. Apt
  • F.S. de Boer
  • E.R. Olderog
  • S. de Gouw
Publication date 2012
Journal Journal of Computer and System Sciences
Volume | Issue number 78 | 3
Pages (from-to) 823-852
Organisations
  • Interfacultary Research - Institute for Logic, Language and Computation (ILLC)
Abstract
We show that verification of object-oriented programs by means of the assertional method can be achieved in a simple way by exploiting a syntax-directed transformation from object-oriented programs to recursive programs. This transformation suggests natural proofs rules and its correctness helps us to establish soundness and relative completeness of the proposed proof system. One of the difficulties is how to properly deal in the assertion language with the instance variables and aliasing. The discussed programming language supports arrays, instance variables, failures and recursive methods with parameters. We also explain how the transformational approach can be extended to deal with other features of object-oriented programming, like classes, inheritance, subtyping and dynamic binding.
Document type Article
Language English
Published at https://doi.org/10.1016/j.jcss.2011.08.002
Downloads
post-print version of article (Accepted author manuscript)
Permalink to this page
Back