网易首页 > 网易号 > 正文 申请入驻

程序分析理论 第三部分 控制流分析 以语法为导向和基于约束

0
分享至

前言

本篇文章是程序分析理论部分第八篇,关于以语义为导向和基于约束的控制流分析,不仅仅有分析语义,还有部分理论证明以及最后的伪代码说明。此外,本篇文章中的例子本身在之前的文章中都出现过,虽然之前也分析过,但是这次增加了新的知识。

以语法为导向的上下文不敏感的控制流分析 Syntax Directed 0-CFA Analysis

经过上一篇的理论证明,我们得到控制流分析存在一个最小的解,但是仅仅根据上一篇文章的分析方法,我们不能利用数学的等式计算出最小解。所以我们以语法为导向得到有限约束集。使得最小解可以计算得到。

对于两个控制流分析的解,如果任意一个的最小解是另一个解的解,那么两解的公共部分一定是包含于真正的最小解之中。

例子 Example

和之前上下文不敏感的控制流分析的抽象化一样,对于let in 结构,我们可以列出这样的式子:(C , p) |= (fun f x => (f ^1(fn y => y ^2) ^3) ^4) ^5 (C , p) |= (g ^6(fn z => z ^7) ^8) ^9 C(5) 包含于 p(g) C(9) 包含于C(10)

对于fun结构,我们列出:{fun f x => (f ^1(fn y => y ^2)^3)^4}包含于C(5) 也包含于p(f) (C , p) |= (f ^1(fn y => y ^2)^3)^4

对于t_1 t_2的结构得到 (C , p) |= f ^1 (C , p) |=(fn y => y ^2)^3。

对于fn 得到{fn y => y ^2}包含于C(3) (C , p) |=y ^2

对于y ^2得到p(y) 包含于 C(2)

对于(C , p) |= (g ^6 (fn z => z ^7) ^8) ^9得到 (C , p) |= g ^6 (C , p) |= (fn z => z ^7) ^8

g为f的结果

{fn z => z ^7} 包含于 C(8) p(z) 包含于C(7)

我们可以最终得到

(C , p) |= (fun f x => (f ^1(fn y => y ^2) ^3) ^4) ^5

(C , p) |= (g ^6(fn z => z ^7) ^8) ^9

(C , p) |= (f ^1(fn y => y ^2)^3)^4

(C , p) |= f ^1

(C , p) |=(fn y => y ^2)^3

(C , p) |=y ^2

(C , p) |= g ^6

(C , p) |= (fn z => z ^7) ^8

上述式子我们可以合并成(C , p) |= (fun f x => (f ^1(fn y => y ^2) ^3) ^4) ^5 (C , p) |= (g ^6(fn z => z ^7) ^8) ^9。

接下来,我们简单证明上面的结果是代码的最小解:我们将整段代码的关系记作(C ^T, p ^T),也就是任意一句包含在这一段代码中的代码的关系(C , p)都包含在(C ^T, p ^T)中,同样的每一句代码的最小解也一定包含于(C ^T, p ^T)中。所以,当(C ^1, p ^1) 和(C ^2, p ^2)拥有一个共同的表达式满足对应关系,那么这个表达式就可以对(C ^1, p ^1) 和(C ^2, p ^2)进行共同描述。

根据上面的定理我们可以得到上述的结果是所有(C , p)的共同描述。

同时,由于(C , p)是有限的,(C , p)的任何描述的子集都在上述结果中,所以上述结果是一个摩尔集,也就是最小解。

基于约束的上下文不敏感的控制流分析Constraint Based 0-CFA Analysis

在之前的分析中,我们已经实际上已经得到了控制流的约束条件。对于上述例子就是满足

C(5) 包含于 p(g)

C(9) 包含于C(10)

f 包含于C(5) 也包含于p(f)

{fn y => y ^2}包含于C(3)

p(y) 包含于 C(2)

p(z) 包含于C(7)

也就是说控制流的约束条件就是满足(C , p) |= e_0的条件

即:(我们将C[]表示为约束条件)

C[c ^l] = 空集

C[x ^l] = {r(x) 包含于 C(l)}

C[(fn x => e_0) ^l] = {{fn x => e_0} 包含于 C(l)} C(e_0)

C[(fun f x => e_0) ^l] = {{fun f x => e_0} 包含于 C(l)} C(e_0) {{fun f x => e_0} 包含于 r(f)}

C[(t_1 ^l_1 t_2 ^l_2) ^l] = C[t_1 ^l_1] C[t_2 ^l_2] 当fn x => t_0 ^l_0在t_1中或者 fun f x => t_0 ^l_0在t_1中 时 C(l_2) 包含于 r(x) C(l_0) 包含于 C(l)

C[(if t_0 ^l_0 then t_1 ^l_1 else t_2 ^l_2) ^l] = C[t_0 ^l_0] C[t_1 ^l_1] C[t_2 ^l_2] C[l_1] 包含于 C[l] C[l_2] 包含于 C[l]

C[(let x = t_1 ^l_1 in t_2 ^l_2) ^l] = C[t_1 ^l_1] C[t_2 ^l_2] C[l_1] 包含于 r[x] C[l_2] 包含于 C[l]

C[(t_1 ^l_1 op t_2 ^l_2) ^l] = C[t_1 ^l_1] C[t_2 ^l_2]

例子Example

根据t_1 t_2的形式以及fn x => x 的形式,我们得到下面结果

C[((fn x = x ^1) ^2 (fn y => y ^3) ^4) ^5] = {

{fn x => x ^1} 包含于 C(2)

r(x) 包含于 C(1)

{fn y => y ^3} 包含于 C(4)

r(y) 包含于C(3)

左表达式包含参数,右表达式对左表达式的参数进行操作 ==> C(4) 包含于 r(x)

C(4)对y进行操作 ==> C(4) 包含于 r(y)

C(1) 包含于 C(5)

C(3) 包含于 C(5)

}

C[e_0] 和 (C , p)关系是C[e_0]是约束关系的实体,(C , p)是约束关系的逻辑表示,(C , p) |= e_0 需要满足 C[e_0] 。约束条件中的C(l) 与 (C , p)的C对应 。r(x) 与 (C , p)中的p对应。

我们对于相互转化的关系用 (C , p) [C(l)] = C(l) 和 (C , p)[r(x)] = p(x)表示。

其中对于基本类型语句t (C , p) [{t}] = {t} 对于本身是运算又会返回值参与其他运算的语句t (C , p) [{t}] 包含于 rhs’ => lhs] = (C , p) [lhs]

所以我们可以得到这样的式子 (C , p) |= C[e]

我们简单证明式子成立且为最小解: 举一个t_1 ^l_1 t_2 ^l_2的例子,l_1的运算结果会运用到t_2中所以(C_1, p_1)包含于(C_2, p_2),也就是约束条件渐渐叠加。因为(C ,p) 是有限个,所以有一个解是极限值,也就是最小解。

在实际应用中,我们可以用链表的形式记录:

对一个C[e]的约束条件,我们生成(C , p)来储存。首先进行初始化,生成空的链表,然后根据语句类型生成限制条件链以及变量,当语句为fn x => x 时将id_x保存至D[C(l)]中并且生成限制条件添加在E[q]中。当语句是其他时,生成限制条件添加在E[q]中。然后根据约束条件生成由最初的根语句对应的工作列表的解逐步演变成最终工作列表的解。即将参数id根据约束条件记录进D[C(l)]中。

我们简单证明该解为最小解:首先,对于第一步和第二步是显然有界的,第三部由于代码块有限,所以约束条件也是有终止的。所以解是可计算的。然后证明为最小解,假设(C‘ , p’) |= C[e] 那么任意D[C(l)] 包含于 C’(l)中 D[r(x)] 包含于 p’(x)中。这在第一步中实现。随后第二部中保证了对于任何形式的t p的处理使得(C , p) |= C[e]始终满足。所以该解为最小解。

根据上面的描述,我们得到以下结论:(C , p) |= C[e] 是最小解,以语法为导向和基于约束的结果是相同的,

伪代码

Init : W = nil D[q] = nil E[q] = nil

Build :

for cc in C[e] : case cc of {t} p : add(p,{t}) p1 p2 : E[p1] = cons(cc,E[p1]) t p => p1 p2:E[p1] = cons(cc,E[p1]) E[p] = cons(cc,E[p])

Iteration :

while W ≠ nil : q = head(W) W = tail(W) for cc in E[q] case cc of p1 p2 : add(p2,D[p1]) {t} p => p1 p2: if t ∈ D[p] then add(p2,D[p1])

最后

欢迎指教
DR@03@星盟

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
脚步不停,梅西在国家队打进108球,仅落后阿里代伊1球

脚步不停,梅西在国家队打进108球,仅落后阿里代伊1球

懂球帝
2024-06-15 10:51:11
历时4年建设 西南地区最大动车所建成投用

历时4年建设 西南地区最大动车所建成投用

封面新闻
2024-06-14 15:31:19
中汽协:5月纯电动汽车出口7.7万辆,同比下降22.3%

中汽协:5月纯电动汽车出口7.7万辆,同比下降22.3%

界面新闻
2024-06-14 14:35:46
要是最后真把FMVP给布朗,今年的最佳阵容是不是就是个笑话?

要是最后真把FMVP给布朗,今年的最佳阵容是不是就是个笑话?

刺头体育
2024-06-14 21:42:40
多位留学生证实韩国大学食堂限量一块肉,拿多就会被人冷眼相待

多位留学生证实韩国大学食堂限量一块肉,拿多就会被人冷眼相待

映射生活的身影
2024-06-13 23:20:16
刘亦菲胖出新高度,被42岁的万茜比下去了,网友:大胖丫头减减肥

刘亦菲胖出新高度,被42岁的万茜比下去了,网友:大胖丫头减减肥

综艺拼盘汇
2024-06-15 11:44:18
北京变态狂魔趁女子兴奋时将其勒死,做成“人彘”供自己欣赏!

北京变态狂魔趁女子兴奋时将其勒死,做成“人彘”供自己欣赏!

小陆搞笑日常
2024-06-15 07:55:09
6月15日起,中国海警将依法抓人,菲律宾搬救兵,美航母进入南

6月15日起,中国海警将依法抓人,菲律宾搬救兵,美航母进入南

纾瑶
2024-06-14 18:12:32
转融通疯狂报复!难怪市场持续下跌!转融通一天新增近1.7亿股!

转融通疯狂报复!难怪市场持续下跌!转融通一天新增近1.7亿股!

股海风云大作手
2024-06-15 08:49:05
伊万刚带国足进18强赛,就点燃第一把火,三大国脚被除名永不叙用

伊万刚带国足进18强赛,就点燃第一把火,三大国脚被除名永不叙用

罗掌柜体育
2024-06-14 17:42:22
惠州第三批房地产融资协调机制“白名单”出炉!

惠州第三批房地产融资协调机制“白名单”出炉!

南方都市报
2024-06-15 12:28:08
同样是泳装照,18岁的刘亦菲和现在一对比,就知道她的生活多放纵

同样是泳装照,18岁的刘亦菲和现在一对比,就知道她的生活多放纵

娱乐皮皮酱
2024-06-15 00:01:56
今年大家发现了一个现象了吗?天气有点反常!

今年大家发现了一个现象了吗?天气有点反常!

叒女紫121
2024-06-15 10:04:24
甘肃一女博士刚生完孩子,丈夫就冲进房间将其割喉:大快人心

甘肃一女博士刚生完孩子,丈夫就冲进房间将其割喉:大快人心

青丝人生
2024-05-24 20:04:21
大便之后要不要用水洗屁股?长期坚持洗的人,对身体有没有好处?

大便之后要不要用水洗屁股?长期坚持洗的人,对身体有没有好处?

资说
2024-06-13 08:01:07
柔宇破产,一个难得的深圳失败样本

柔宇破产,一个难得的深圳失败样本

深圳客
2024-06-14 20:32:52
三只羊集体参加快乐向前冲,女主播身材满分,嘴哥一人拿两台冰箱

三只羊集体参加快乐向前冲,女主播身材满分,嘴哥一人拿两台冰箱

新游戏大妹子
2024-06-13 11:46:12
新 iPhone 曝光,7.9 英寸

新 iPhone 曝光,7.9 英寸

果粉俱乐部
2024-06-15 11:50:48
花了30万跟风旅游,那家中产再次崩溃

花了30万跟风旅游,那家中产再次崩溃

ELLEMEN 睿士
2024-06-13 16:06:19
董宇辉再惹争议!大批游客因他在景区外暴晒3小时,相关部门为甩责互踢皮球

董宇辉再惹争议!大批游客因他在景区外暴晒3小时,相关部门为甩责互踢皮球

可达鸭面面观
2024-06-14 12:11:52
2024-06-15 13:06:44
安全客
安全客
有思想的安全新媒体
1360文章数 4743关注度
往期回顾 全部

科技要闻

TikTok开始找退路了?

头条要闻

海南儋州一小区地库墙被质疑使用"海砂" 官方最新通报

头条要闻

海南儋州一小区地库墙被质疑使用"海砂" 官方最新通报

体育要闻

残暴的德国战车,和苏格兰的祖传倒霉蛋

娱乐要闻

江宏杰秀儿女刺青,不怕刺激福原爱?

财经要闻

新情况!高层对人民币的态度180°转弯

汽车要闻

东风奕派eπ008售21.66万元 冰箱彩电都配齐

态度原创

房产
本地
健康
数码
军事航空

房产要闻

万华对面!海口今年首宗超百亩宅地,重磅挂出!

本地新闻

粽情一夏|海河龙舟赛,竟然成了外国人的大party!

晚餐不吃or吃七分饱,哪种更减肥?

数码要闻

意外之喜,苹果 macOS 15 Sequoia 预装新版国际象棋游戏:更精致

军事要闻

美国与乌克兰签署双边安全协议

无障碍浏览 进入关怀版