39、Java数组边界检查消除的综合方法

Java数组边界检查消除的综合方法

1. 约束图状态变化示例

首先来看一个简单的代码示例及其对应的约束图状态变化:

s0 : i = j + 2;
s1 : a[i] = · · · ;
s2 : i = · · · ;
s3 : a[j] = · · · ;

语句 s1 会生成约束 i - a ≤ -1 0 - i ≤ 0 ,从而在约束图中产生从 a i 以及从 i 0 的边。通过累加边的权重,从 a j 的路径意味着约束 j - a ≤ -3 。在语句 s2 中, i 失去了来自 a j 的约束,路径 a → i → j 不再存在,但通过一条权重为 -3 的直接从 a j 的新边,约束条件仍然得以保留。因此,在执行语句 s3 之前,约束 j - a ≤ -3 仍然有效,这使得 s3 的上界检查可以被证明是安全的。

2. 数据流分
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值