Verification of Sequential and Concurrent Programs

Computer programs are an indispensable part of many of the systems we rely upon in our daily lives, and the proper functioning and safety of these systems is of paramount importance. The development of methods that ensure program correctness is therefore a key challenge for computer scientists. This...

Full description

Bibliographic Details
Main Authors: Apt, Krzysztof R. (Author), Boer, Frank S. (Author), Olderog, Ernst-R<U+00fc>diger. (Author)
Corporate Author: SpringerLink (Online service)
Format: Electronic
Language:English
Published: London : Springer London, 2009.
Series:Texts in Computer Science,
Subjects:
Online Access:https://ezaccess.library.uitm.edu.my/login?url=http://dx.doi.org/10.1007/978-1-84882-745-5
LEADER 05186nam a22005175i 4500
001 5998
003 DE-He213
005 20130725192844.0
007 cr nn 008mamaa
008 100301s2009 xxk| s |||| 0|eng d
020 # # |a 9781848827455  |9 978-1-84882-745-5 
024 7 # |a 10.1007/978-1-84882-745-5  |2 doi 
050 # 4 |a QA76.9.L63 
050 # 4 |a QA76.5913 
050 # 4 |a QA76.63 
072 # 7 |a UM  |2 bicssc 
072 # 7 |a UYF  |2 bicssc 
072 # 7 |a COM051000  |2 bisacsh 
072 # 7 |a COM036000  |2 bisacsh 
082 0 4 |a 005.1015113  |2 23 
100 1 # |a Apt, Krzysztof R.  |e author. 
245 1 0 |a Verification of Sequential and Concurrent Programs  |c by Krzysztof R. Apt, Frank S. Boer, Ernst-R<U+00fc>diger Olderog.  |h [electronic resource] / 
264 # 1 |a London :  |b Springer London,  |c 2009. 
300 # # |a XXIV, 502p. 26 illus.  |b online resource. 
336 # # |a text  |b txt  |2 rdacontent 
337 # # |a computer  |b c  |2 rdamedia 
338 # # |a online resource  |b cr  |2 rdacarrier 
347 # # |a text file  |b PDF  |2 rda 
490 1 # |a Texts in Computer Science,  |x 1868-0941 
505 0 # |a Part I: In the Beginning -- Introduction -- Preliminaries -- Part II: Deterministic Programs -- while Programs -- Recursive Programs -- Recursive Programs with Parameters -- Object-Oriented Programs -- Part III: Parallel Programs -- Disjoint Parallel Programs -- Parallel Programs with Shared Variables -- Parallel Programs with Synchronization -- Part IV: Nondeterministic and Distributed Programs -- Nondeterministic Programs -- Distributed Programs -- Fairness. 
520 # # |a Computer programs are an indispensable part of many of the systems we rely upon in our daily lives, and the proper functioning and safety of these systems is of paramount importance. The development of methods that ensure program correctness is therefore a key challenge for computer scientists. This widely anticipated third edition of Verification of Sequential and Concurrent Programs provides a systematic exploration of one of the most common approaches to program verification, known as the "assertional" approach. Following the successful formula of previous editions, this approach is applied to deterministic and nondeterministic sequential programs of varying complexity, together with both parallel and distributed concurrent programs. The expanded content of this thorough new edition also includes coverage of the verification of object-oriented programs. For each class of programs, the authors introduce an operational semantics and proof systems for the verification of partial and total correctness, justified formally in corresponding soundness theorems. Case studies supplied throughout the book demonstrate the use of the proof systems to formally verify solutions to classical problems, such as sorting, manipulation of lists, producer/consumer and mutual exclusion. Topics and Features: Includes a thorough introductory section, familiarizing the reader with the basic concepts and notation used in the book, as well as the book<U+0019>s structure Explains Hoare<U+0019>s approach to program verification for while programs, providing a correctness proof of a program for partitioning an array (NEW) Concludes each chapter with exercises and bibliographic remarks for further reading Discusses recursive programs that extend deterministic programs by parameterless procedures and procedures with the call-by-value parameter mechanism, and provides a correctness proof of the quicksort program (NEW) Explores nondeterministic and distributed programs, presenting a verification method of distributed programs based on a transformation into nondeterministic ones Presents object-oriented programs, with a focus on the main characteristics of objects (NEW) Investigates parallel programs with shared variables and with synchronization Studies the issue of fairness in the framework of nondeterministic programs, using an approach based on the method of explicit schedulers Includes a Foreword by Professor Amir Pnueli This modern update of a classic, reader-friendly textbook is perfect for an introductory course on program verification for advanced undergraduate or graduate students, and may also be used as an introduction to operational semantics. Outlines for possible courses are suggested in the Preface to the book. This book is unique in addressing assertional verification of all essential classes of imperative programs: while programs, recursive programs, object-oriented programs, nondeterministic programs, parallel programs, and distributed programs. 
650 # 0 |a Computer science. 
650 # 0 |a Logic design. 
650 1 4 |a Computer Science. 
650 2 4 |a Logics and Meanings of Programs. 
650 2 4 |a Mathematical Logic and Formal Languages. 
700 1 # |a Boer, Frank S.  |e author. 
700 1 # |a Olderog, Ernst-R<U+00fc>diger.  |e author. 
710 2 # |a SpringerLink (Online service) 
773 0 # |t Springer eBooks 
776 0 8 |i Printed edition:  |z 9781848827448 
830 # 0 |a Texts in Computer Science,  |x 1868-0941 
856 4 0 |u https://ezaccess.library.uitm.edu.my/login?url=http://dx.doi.org/10.1007/978-1-84882-745-5 
912 # # |a ZDB-2-SCS 
950 # # |a Computer Science (Springer-11645)