摘要
对高可信软件需求的增加使得指针程序的验证成为近期的研究热点.指针逻辑作为Hoare逻辑的扩展,可以对指针程序进行精确的分析.介绍一个针对指针逻辑的自动定理证明器的设计和实现,描述了一些算法.实验结果表明,该定理证明器可以完全自动的证明用类C语言编写的关于单链表,双链表和二叉树的指针程序的验证条件,并生成机器可检查的证明.
The increasing demands for high-assurance software make the verification of pointer programs a hot research point. As an extension of Hoare logic,Pointer Logic can be used for accurate pointer analysis of pointer programs. This paper introduces some details in designing and implementing of an automated theorem prover for Pointer Logic,and describes some algorithms. The experimental results show our implementation can fully automatically prove the verification conditions for pointer programs in C-like language and produce machine-checkable proofs. The programs for testing are mainly about singly-linked lists,doubly-linked lists and binary trees.
出处
《小型微型计算机系统》
CSCD
北大核心
2010年第5期801-806,共6页
Journal of Chinese Computer Systems
基金
国家自然科学基金项目(60673126
90718026)资助
Intel中国研究中心资助
关键词
指针逻辑
验证条件
自动定理证明器
证明检查算法
pointer logic
verification condition
automated theorem prover
proof checking algorithm