软件构造课堂延伸(2) 支配树

本文介绍了支配树的概念及其在程序性能分析中的应用。支配树能够展示内存导出文件中最大的对象,并帮助研究使其他对象存活的对象。文章还解释了如何构建支配树。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在动态分析程序性能时,遇到了支配树这个概念,下面详细解释一下什么叫做支配树。

支配树(Dominator tree)

支配树展示了内存导出文件中最大的对象。

支配树是用来研究使得其它对象存活的对象的强有力工具。

支配树是将原来内存中的应用关系图转化为一个树形结构,这个树形结构的特点是:

所有节点的儿子节点都会因为父节点的死亡而变得不可达,因而也就处于死亡状态。


上面这幅图简要的说明了支配树的建立过程。(图来自于哈工大2018春软件构造课程)

如果到达左边的图的一个节点的所有路径中都包含节点x,那么节点x在树结构中就因该是该节点的祖先节点。

如果在原来的图中两点距离最近,就设置为父子节点。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值