汇编实现地址对应值相加

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ma2595162349/article/details/90728949

          先来看一段汇编代码:

          

         上面一段程序的作用是计算ffff:0~ffff:3单元中数据的和,最终结果保存在dx寄存器中。ds是一个段寄存器,通常用来存放要访问数据的短地址,ds的值后面[bx]会用到。8086CPU不支持将数据直接送入段寄存器的操作,所以需要ax寄存器作为中转,就要对ax先赋值。

        [bx]为ds*16+bx对应地址的值,'[]'会自动读取ds段寄存器的值。因为ffff:0~ffff:3中的数据是8位的,而寄存器是16位的,所以执行mov操作时先对其地位的4位进行操作,即mov al,[bx](al表示ax low),然后对其高位进程操作。inc指令是对目标操作数+1,使得累加后指向下一个地址的值。 下面看一下单步调试的结果:

       ffff:0~ffff:3对应的值如下

       

       分别为 EA D4 04,16进制的1个位对应二进制的4个位,所以它们都是8位的。

      

      

       上面是程序的部分执行过程,最后dx=01c2,是EA D4 04之和。cx=0表明循环结束。

参考资料:<<汇编语言>>王爽

猜你喜欢

转载自blog.csdn.net/ma2595162349/article/details/90728949