1.1.2.2 前驱图

前趋图(Precedence Graph):是一个有向无循环图,记为DAG(Directed Acyclic Graph),前趋图中必须不存在循环, 该图通常用于 表现事务之间先后顺序的制约关系
结点:可以表示一个语句、一个程序段或是一个进程,
有向边: 结点间的有向边表示两个结点之间存在的前趋关系。
 
程序顺序执行 特性
  • 顺序性
  • 封闭性:即程序运行时独占全机资源
  • 可再现性
 
程序并发执行特性
  • 间断性
  • 失去封闭性:是多个程序共享系统中的各种资源
  • 不可再现性
在计算机中,经常采用流水线方式执行指令,每一条指令都可以分解为取指、分析 和执行三步。
 
  • 〇 表示一个程序、进程或是语句的结点。
  • → 表示结点间的执行顺序。
 
前趋关系"→"的形式化描述:→ ={Ai, Bi, Ci}  取指操作为 Ai,分析操作为 Bi 和执行操作为 Ci(i=1,2,3)。
如图所示为三个任务各程序段并发执行的前驱图。
开始结点 Initial Node ):A1 没有前趋结点,不受任何制约,可以直接执行
终止结点 Final Node ): C3 没有后继结点
直接前驱: Bi开始执行之前Ai必须完成, 此时称 Ai 是 Bi 的 直接前驱
接后继: Bi开始执行之前Ai必须完成, 此时称  Bi Ai  的 直接前驱
重量( Weight 用于表示该结点所含有的程序量或程序的执行时间
在前趋图中, 执行先后顺序的制约关系 可分为两种: 直接制约 间接制约
直接制约: 同操作中 多个步骤之间 的制约关系,也可以说是“同步的进程之间的制约关系”。 如图 A1、B1、C1 是一条指令的取指、分析、执行的三个步骤,所以它们之间的关系是直接制约。
间接制约: 多个操作之间 相同步骤 的制约关系,也可以说是“互斥的进程之间的制约关系”。 如图A1、A2、A3 之间就存在间接制约的关系。
并行执行: B1、A2,
       C1、B2、A3,
       C2、B3,
 
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值