8086汇编-24[BX]和Loop指令02

#pragma once
/*    24-[BX]和Loop指令02

  Loop指令
    指令的格式是:loop 标号,CPU 执行loop指令的时候,要进行两步操作:

        ① (cx)=(cx)-1;
        ② 判断cx中的值,不为零则转至标号处执行程序,如果为零则向下执行。

    从上面的描述中,我们可以看到,cx中的值影响着loop指令的执行结果。

    通常(注意,我们说的是通常)我们用loop指令来实现循环功能,cx 中存放循环次数。            cx 是通用寄存器里面的, 累加器.

    这里我们讲解loop指令的功能,关于loop指令如何实现转至标号处的细节,将在后面的课程中讲解。下面我们通过一个程序来看一下loop指令的具体应用:

        任务1:编程计算2^2,结果存放在ax中。
            分析:
            设(ax)=2,可计算:(ax)= (ax)*2,最后(ax)中为2^2的值。N*2可用N+N 实现。

            程序代码:
               assume cs:code
               code segment
                    mov ax,2
                    add ax,ax

                    mov ax,4c00h
                    int 21h
               code ends
               end

        任务2:编程计算2^3。
           分析:
           2^3=2*2*2,若设(ax)=2,可计算:(ax)= (ax)*2*2,最后(ax)中为2^3的值。N*2可用N+N 实现。

           程序代码
                assume cs:code
                    code segment
                    mov ax,2
                    add ax,ax
                    add ax,ax

                    mov ax,4c00h
                    int 21h
                    code ends
                end


        任务3:编程计算2^12。
           分析:
           2^12=2*2*2*2*2*2*2*2*2*2*2*2,若设(ax)=2,可计算:
           (ax)= (ax)*2*2*2*2*2*2*2*2*2*2*2,最后(ax)中为2^12的值。N*2可用N+N 实现。

            程序代码:
               assume cs:code
               code segment
                    mov ax,2
                    ;做11次add ax,ax
                    mov ax,4c00h
                    int 21h
               code ends
               end

            按照我们的算法,计算2^12需要11条重复的指令add ax, ax。我们显然不希望这样来写程序,这里,可用loop来简化我们的程序。
            程序代码:
               assume cs:code
               code segment
                    mov ax,2
                    mov cx,11            loop 的条件哦~ 表示执行11 次,当然这是loop 自己的机制, 不是cx 的机制,cx 最开始的时候存放的是程序默认的大小
                s:  add ax,ax            这里的s 是一个标号
                    loop s                loop 会跳到 标号的地方 执行,此时cx 自减1, cx 减到 0 的时候,loop 才会不执行,先自减,然后再跳.   Loop 中自带更改IP 的值.

                    mov ax,4c00h
                    int 21h
               code ends
               end

    程序分析: 
            (1)标号在汇编语言中,标号代表一个地址,此程序中有一个标号s 。它实际上标识了一个地址,这个地址处有一条指令:add ax,ax。
            (2)loop s
                CPU 执行loop s的时候,要进行两步操作:
                ① (cx)=(cx)-1;
                ② 判断cx 中的值,不为0 则转至标号s 所标识的地址处执行(这里的指令是“add ax,ax),如果为零则执行下一条指令(下一条指令是mov ax,4c00h)。
            (3)以下三条指令
                   mov cx,11 
               s:  add ax,ax 
                   loop s

                执行loop s时,首先要将(cx)减1,然后若(cx)不为0,则向前转至s处执行add ax,ax。所以,我们可以利用cx来控制add ax,ax的执行次数。
                    标号的名字不能起太多,最多32个字符.


    下面我们详细分析一下这段程序的执行过程,从中体会如何用cx 和loop s 相配合实现循环功能。(微软的编译器默认是十进制的,如果要进行十六进制的数据,要在数据后面加H 例如:0001H)


*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值