111111
精灵王
精灵王
  • 注册日期2010-12-08
  • 发帖数640
  • QQ
  • 火币1103枚
  • 粉丝120
  • 关注75
  • 社区明星
阅读:1873回复:0

经典汇编语言教程:5.2.8 循环指令

楼主#
更多 发布于:2013-01-24 14:29

循环结构是程序的三大结构之一。为了方便构成循环结构,汇编语言提供了多种循环指令,这些循环指令的循环次数都是保存在计数器CX或ECX中。除了CX或ECX可以决定循环是否结束外,有的循环指令还可由标志位ZF来决定是否结束循环。
在高级语言中,循环计数器可以递增,也可递减,但汇编语言中,CX或ECX只能递减,所以,循环计数器只能从大到?T诔绦蛑校匦胂劝蜒反问掣芳剖鳌?/p>
汇编语言的循环指令都是放在循环体的下面,在循环时,首先执行一次循环体,然后把循环计数器CX或ECX减1。当循环终止条件达到满足时,该循环指令下面的指令将是下一条被执行的指令,否则,程序将向上转到循环体的第一条指令。
在循环未终止,而向上转移时,规定:该转移只能是一个短转移,即偏移量不能超过128,也就是说循环体中所有指令码的字节数之和不能超过128。如果循环体过大,可以用后面介绍的“转移指令”来构造循环结构。
循环指令本身的执行不影响任何标志位。
1、循环指令(Loop UntilComplete)
循环指令LOOP的一般格式:

LOOP 标号
LOOPW 标号 ;CX作为循环计数器,80386+
LOOPD 标号 ;ECX作为循环计数器,80386+
循环指令的功能描述:


图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。
XORAX, AX
MOVCX, 1000D
again:ADDAX, CX;计算过程:1000+999+…+2+1
LOOPagain
方法2:不用循环计数器进行累加,求和式子仍为:1+2+…+999+1000。
XORAX, AX
MOVCX, 1000D
MOVBX, 1
again:ADDAX, BX;计算过程:1+2+…+999+1000
INCBX
LOOPagain

从程序段的效果来看:方法1要比方法2好。

喜欢0 评分0
游客

返回顶部