8085微处理器中零结果调用(CZ)


在8085指令集中,CZ是一个助记符,代表“如果为零则调用”。仅当Z标志值为1时,此指令才用于跳转到指令中提供的16位地址的子程序。如果Z标志值为0,则程序流程按顺序继续执行主程序。这是一个3字节指令。

助记符,操作数
操作码(十六进制)
字节数
CZ标签
CC
3


让我们考虑以下示例代码以更好地解释:

地址
十六进制代码
助记符
注释
2000
31
LXI SP, 5000H
SP ← 5000H. 初始化堆栈指针
2001
00


地址的低位字节
2002
50


地址的高位字节
2003
3E
MVI A, 40H
A ← 40H,用初始值40H初始化累加器
2004
40


操作数为40H
2005
06
MVI B, 40H
B ← 40H,用初始值50H初始化寄存器B
2006
40


操作数为40H
2007
90
SUB B
A ← A – B = 40H – 40H = 00H,由于计算结果为零,所以 Z = 1
2008
CC
CZ 2010H
由于 Z = 1,调用地址为 2010H 的子程序。因此,程序的控制将转移到 2010H 位置。下一个指令的返回地址 200BH 将被压入堆栈顶部。结果,4FFFH (SP – 1) 将包含 20H,4FFEH (SP – 2) 将分别包含 0BH。
2009
10


地址的低位字节
200A
20


地址的高位字节
200B
21
LXI H, 4050H
HL ← 4050H,初始化 HL 寄存器对。执行 RET 指令后,控制将返回到此指令。
200C
50


地址的低位字节
200D
40


地址的高位字节
200E
77
MOV M, A
M ← A,累加器的內容将被传输到 HL 寄存器对指向的内存位置 4050H。因此,在 4050H 内存位置将存储累加器的內容 40H。
200F
76
HLT
程序结束。
2010
80
ADD B
A ← A + B = 00H + 40H = 40H
2011
C9
RET
将控制返回到地址 200BH。返回地址 200BH 将从堆栈顶部弹出。因此,从地址 4FFEH 弹出 0BH,从地址 4FFFH 弹出 20H,SP 将相应地恢复其初始地址 5000H。


针对此指令 **CZ 2010H** 执行的时序图如下:

**总结** − 因此,此指令 **CZ** 需要 3 个字节、5 个机器周期(操作码获取、内存读取、内存读取、内存写入、内存写入)和 18 个 T 状态才能执行,如时序图所示。


更新于:2020年6月27日

407 次查看

启动您的职业生涯

完成课程获得认证

开始学习
广告
© . All rights reserved.