- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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、模仿二叉排序树的归纳定义,给
您可能关注的文档
- 兰州大学药学院副班主任工作细则.doc
- 南昌市2018年度城区小学升初中.doc
- 英语高考语法填空解题思路及技巧.doc
- 铜川市2015年度事业单位公开招聘人员报考指南.doc
- 山西以工代赈管理实施细则.doc
- 关于美国期权史上的三次交易禁令、四次试点与两大报告.doc
- 英语1第1次网上作业.doc
- 2017年度质量监督工作计划编制说明.docx
- 遗传学综合试卷试题一.doc
- 第3讲我有学习金钥匙.doc
- 急性肾功能衰竭综合征的肾血管介入性诊治4例报告并文献复习.docx
- 基于血流动力学、镇痛效果分析右美托咪定用于老年患者髋部骨折术的效果.docx
- 价格打骨折 小心统筹车险.docx
- 交通伤导致骨盆骨折合并多发损伤患者一体化救治体系的效果研究.docx
- 多层螺旋CT与DR片诊断肋骨骨折的临床分析.docx
- 儿童肱骨髁上骨折后尺神经损伤恢复的预测因素分析.docx
- 康复联合舒适护理在手骨折患者中的应用及对其依从性的影响.docx
- 机器人辅助老年股骨粗隆间骨折内固定术后康复.docx
- 超声辅助定位在老年髋部骨折患者椎管内麻醉中的应用:前瞻性随机对照研究.docx
- 两岸《经济日报》全面合作拉开帷幕.docx
最近下载
- 护理组长竞聘ppt.pptx VIP
- 《单位消防安全管理规范》DB32T4444—2023.pdf VIP
- 特别管控危险化学品目录.pdf VIP
- DB52_T 1896-2025 血站工作人员培训指南.pdf VIP
- DB44_T 2652-2025 乡村旅游酒店质量规范.docx VIP
- 2023 年全省普通高中学业水平等级考试-2023年山东卷物理真题(答案).pdf VIP
- DB51_T 3308-2025 公路桥梁复合转体技术规程.pdf VIP
- DB52_T 1895-2025 基岩区构造地球化学弱信息提取技术规程.pdf VIP
- 公司督察笔试题及答案.docx VIP
- 中国居民养老财富管理发展报告(2025).pdf
原创力文档


文档评论(0)