形状图逻辑与形状系统.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * 循环不变形状图的推断 循环不变形状图推断的算法框架 对于循环:while (B) S (1)计算循环前条件G0 = Gpre。i = 0 (2)根据形状图逻辑的规则计算G?i , 使得{Gi ? B} S {G?i+1 } (3)应用抽象规则计算Gi+1,使得 G?i+1? Gi+1 (4)若Gi+1 ? G0?…?Gi,则G0?…?Gi是循环不变形状图;否则,i = i + 1,转(2) 循环不变形状图的推断 保证算法终止的措施一:使用虚拟变量 对于“应用抽象规则计算Gi+1,使得 G?i+1? Gi+1 循环的特点:遍历或生成的节点应该能浓缩 保证能抽象的措施:为循环体的每条执行路径都设有累计该路径执行次数的虚拟变量,先用虚拟变量进行抽象 目前系统的不足:尚未用程序分析技术去寻找含声明变量的线性表达式,以代替虚拟变量 p n ? ? h m-j, m-j=0 n n ? p1 p2 n j-1, j-1=0 循环不变形状图的推断 保证算法终止的措施二:形状检查 双向链表 h ? r r . . . r r l l l l ? r l 循环迭代依次把域指针l都赋值为NULL h ? r r . . . r r l l l l ? r ? ? ? 形状系统拒绝这样的程序,因为它偏离了声明的形状 循环不变形状图的推断 保证算法终止的措施三:限制整型表达式 将程序员提供的与形状有关的整型表达式限制到线性表达式 在形状分析中产生的也是线性表达式 p n ? ? h m-j, m-j=0 n n ? p1 p2 n j-1, j-1=0 循环不变形状图的推断 算法终止的理由 声明指针的个数有限 相邻2个声明指针所指向节点之间的节点数有限 (不超过3个) 在循环体结束点能形成的不等价形状图有限 P p l P r r q s r tree tree l P tree l tree r P P tree l 报 告 提 纲 形状图逻辑 形状图,形状图的变换规则,形状图的语义,形状图逻辑 形状系统 形状定义、形状推断、形状检查 循环不变形状图的推断 复杂易变数据结构的解决方案 复杂易变数据结构的解决方案 数据结构的嵌套 例:双向链表的每个节点都有一个单链表 h ? r r . . . r r l l l l ? r l s next ? s next ? s next ? s next ? 解决办法: 1、程序员声明域指针的不同作用 2、限定这些单链表都是表长不确定的单链表 复杂易变数据结构的解决方案 有附加单链表的数据结构 例:用附加单链表把数据结构上的部分节点链起来 困难之处:附加单链指针的指向不能静态确定 解决办法: 1、将附加单链从主链上剥离,建一个虚拟单链表 h ? r r . . . r r l l l l ? r l a s a 复杂易变数据结构的解决方案 有附加单链表的数据结构 例:用附件单链表把数据结构上的部分节点链起来 困难之处:附加单链指针的指向不能静态确定 解决办法: 1、将附加单链从主链上剥离,建一个虚拟单链表 2、程序员声明附加链指针,增加一些编程约束 h ? r r . . . r r l l l l ? r l s a ? a 复杂易变数据结构的解决方案 有确定的附加指针的数据结构 例如:队列,带父节点指针的二叉树,left-child right-sibling tree with two kinds of backward links 解决办法: 1、已经定义的5种数据结构作为骨架 2、程序员描述附加指针与骨架上指针之间的关系 3、骨架形状的正确性由形状系统完成 4、从(2)的描述产生附加指针的检查代码 复杂易变数据结构的解决方案 例:带父节点指针的二叉树 描述父节点指针和 骨架二叉树的指针之间的关系 p_tree(s) ? s == NULL ? s != NULL ? s-parent == NULL ? ptree(s) ptree(s) ? (s-left != NULL ? s-left-parent == s ? ptree(s-left)) ? (s-right!=NULL ? s-right-parent==s? ptree(s-right)) ? … …. …. …. s 作 业 1、模仿二叉排序树的归纳定义,给

文档评论(0)

187****5045 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档