循环结构是程序的三大结构之一。为了方便构成循环结构,汇编语言提供了多种循环指令,这些循环指令的循环次数都是保存在计数器CX或ECX中。除了CX或ECX可以决定循环是否结束外,有的循环指令还可由标志位ZF来决定是否结束循环。
在高级语言中,循环计数器可以递增,也可递减,但汇编语言中,CX或ECX只能递减,所以,循环计数器只能从大到小
汇编语言的循环指令都是放在循环体的下面,在循环时,首先执行一次循环体,然后把循环计数器CX或ECX减1。当循环终止条件达到满足时,该循环指令下面的指令将是下一条被执行的指令,否则,程序将向上转到循环体的第一条指令。
在循环未终止,而向上转移时,规定:该转移只能是一个短转移,即偏移量不能超过128,也就是说循环体中所有指令码的字节数之和不能超过128。如果循环体过大,可以用后面介绍的“转移指令”来构造循环结构。
循环指令本身的执行不影响任何标志位。
1、循环指令(Loop UntilComplete)
循环指令LOOP的一般格式: LOOP 标号 LOOPW 标号 ;CX作为循环计数器,80386+ LOOPD 标号 ;ECX作为循环计数器,80386+ 循环指令的功能描述: http://www.zznews.cn/hyzx/jkxx/5406327705.html http://www.lfxww.com/2014/shichangshangxun/2014/0416/804574.html http://zx.zynews.com/hyzx/yskt/5390123823.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563788.html http://zx.zynews.com/hyzx/yskt/5398098762.html http://www.zznews.cn/hyzx/jkxx/5394137056.html http://www.yltvb.com/xwbk/redianxinwen/5389545718.html http://zx.zynews.com/hyzx/yskt/5398102537.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563789.html http://www.zznews.cn/hyzx/jkxx/5394172683.html http://www.lfxww.com/2014/shichangshangxun/2014/0416/807380.html http://zx.zynews.com/hyzx/yskt/5398105715.html http://www.zznews.cn/hyzx/jkxx/5394208967.html http://www.lfxww.com/2014/shichangshangxun/2014/0416/807393.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563790.html http://www.lfxww.com/2014/shichangshangxun/2014/0416/807397.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563791.html http://zx.zynews.com/hyzx/yskt/5398108045.html http://zx.zynews.com/hyzx/yskt/5398111150.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563792.html http://www.zznews.cn/hyzx/jkxx/5394212839.html http://zx.zynews.com/hyzx/yskt/5398113539.html http://www.changsha.cn/bj/yl/xywy/2014/0416/563793.html http://www.zznews.cn/hyzx/jkxx/5394215834.html http://zx.zynews.com/hyzx/yskt/5398117977.html http://www.lfxww.com/2014/shichangshangxun/2014/0416/807428.html http://zx.zynews.com/hyzx/yskt/5398161349.html | 图5.12 循环指令LOOP的功能示意图 |
◆ | (CX)=(CX)-1或(ECX)=(ECX)-1; |
◆ | 如果(CX)≠0或(ECX)≠0,转向“标号”所指向的指令,否则,终止循环,执行该指令下面的指令。 |
例5.13 编写一段程序,求1+2+…+1000之和,并把结果存入AX中。
解: |
| 方法1:因为计数器CX只能递减,所以,可把求和式子改变为:1000+999+…+2+1。 |
| … |
XOR | AX, AX |
MOV | CX, 1000D |
again: | ADD | AX, CX | ;计算过程:1000+999+…+2+1 |
LOOP | again |
… |
方法2:不用循环计数器进行累加,求和式子仍为:1+2+…+999+1000。 |
| … |
XOR | AX, AX |
MOV | CX, 1000D |
MOV | BX, 1 |
again: | ADD | AX, BX | ;计算过程:1+2+…+999+1000 |
INC | BX |
LOOP | again |
… |