8085 微处理器中非零调用 (CNZ) 结果
在 8085 指令集中,**CNZ** 是一个助记符,代表“非零调用”。仅当 Z 标志值为 0 时,此指令才用于跳转到指令中提供的 16 位地址的子程序。如果 Z 标志值为 1,则程序流程按顺序在主程序中继续。它是一个 3 字节指令。
助记符,操作数 | 操作码(十六进制) | 字节 |
---|---|---|
CNZ 标签 | C4 | 3 |
让我们考虑以下示例代码以更好地解释 -
地址 | 十六进制代码 | 助记符 | 注释 |
---|---|---|---|
2000 | 31 | LXI SP, 5000H | SP ← 5000H. 初始化 SP |
2001 | 00 | 地址的低位字节 | |
2002 | 50 | 地址的高位字节 | |
2003 | 3E | MVI A, 40H | A ← 40H,用初始值 40H 初始化累加器 |
2004 | 40 | 40H 作为操作数 | |
2005 | 06 | MVI B, 30H | B ← 30H,用初始值 30H 初始化寄存器 B |
2006 | 30 | 30H 作为操作数 | |
2007 | 90 | SUB B | A ← A – B= 40H – 30H = 10H,由于计算结果为非零,因此 Z = 0 |
2008 | C4 | CNZ 2010H | 由于 Z = 0,因此调用地址为 2010H 的子程序。因此,程序的控制权将转移到位置 2010H。下一个指令的地址 200BH(即地址)将被压入堆栈顶部。结果,4FFFH(SP – 1)将包含 20H,而 4FFEH(SP – 2)将分别包含 0BH。 |
2009 | 10 | 地址的低位字节 | |
200A | 20 | 地址的高位字节 | |
200B | 21 | LXI H, 4050H | HL ← 4050H,初始化 HL 寄存器对。执行指令后,控制权将返回到此指令。 |
200C | 50 | 地址的低位字节 | |
200D | 40 | 地址的高位字节 | |
200E | 77 | MOV M, A | M ← A,累加器的内容将被传输到内存位置 4050H,因为它由 HL 寄存器对指向。因此,在 4050H 内存位置将存储累加器的内容 40H。 |
200F | 76 | HLT | 程序结束。 |
2010 | 80 | ADD B | A ← A + B ← 10H + 30H = 40H |
2011 | C9 | RET | 将控制权返回到地址 200BH。返回地址 200BH 将从堆栈顶部弹出。因此,从地址 4FFEH 弹出 0BH,从地址 4FFFH 弹出 20H,并且 SP 会相应地将其内容恢复为初始地址 5000H。 |
针对此指令 **CNZ 2010H** 执行的时间图如下所示 -
**总结** - 因此,此指令 **CNZ** 需要 3 个字节、5 个机器周期(操作码获取、内存读取、内存读取、内存写入、内存写入)和 18 个 T 状态才能执行,如时间图所示。
广告