Verification of Object Oriented Programs Using Class Invariants [chapter]

Kees Huizing, Ruurd Kuiper
2000 Lecture Notes in Computer Science  
A proof system is presented for the verification and derivation of object oriented programs with as main features strong typing, dynamic binding, and inheritance. The proof system is inspired on Meyer's system of class invariants [12] and remedies its unsoundness, which is already recognized by Meyer. Dynamic binding is treated in a flexible way: when throughout the class hierarchy overriding methods respect the preand postconditions of the overridden methods, very simple proof rules for method
more » ... calls suffice; more powerful proof rules are supplied for cases where one cannot or does not want to follow this restriction. The proof system is complete relative to proofs for properties of pointers and the data domain.
doi:10.1007/3-540-46428-x_15 fatcat:5h4b42nwarh6loqdzzivmj7awe