求大佬帮帮忙
王爽老师的汇编语言教材5.5开头计算ffff:0~ffff:b中的数据的和,结果储存在dx中,这里为什么要用ax做跳板啊,它与dx不都是16位寄存器嘛,难道这里文章是说
ax与dx的数据类型不一样?{:10_302:} 第一,因为你计算的时候,是计算每个字节单元的值的和,而不是每个字单元的值得和。
第二,如果你只AL来计算的话,如果和大于FF的话,就会回到00,造成计算结果的错误,所以需要AH赋0,MOV AL,,然后用AX来做计算,相当
你用16位的寄存器计算8位的加法,即使你需要计算的12个值即使全部是FF,也不会大于FFFF这个值,才能保证的了你的结果是正确的
不知道这么说你能听明白不 ax 和 dx 虽然都是 16 位的寄存器,但是,在设计它们的时候,不同的寄存器在不同的指令中担当的角色不同,因而,各个寄存器的用途和作用也会有所区别, 有些情况可以混淆,另外一些时候不能混淆。 zyk524 发表于 2020-10-30 22:33
第一,因为你计算的时候,是计算每个字节单元的值的和,而不是每个字单元的值得和。
第二,如果你只AL来计 ...
{:7_113:}
页:
[1]