汇编语言_编程任务(小甲鱼老师ppt上的)
assume cs:code ;编程计算1EF000H+201000H,结果放在ax(高16位)和bx(低16位)中。code segment ;提前构思,在ax和bx中分别进行高16位和低16位的运算,然后看低16位是否产生进位,也就是是否CY,是的话就在高16位加1
start:mov ax,1Eh ;第一个数的高位给与ax
add ax,20h ;两个数的高位相加,结果放置于ax
mov bx,0F000H ;第一个数的低位给与bx
add bx,1000H ;两个数低位相加,结果放置于bx
jnc ok ;当cf为NC时(无进位),则跳转至结束
inc ax ;当cf为时CY(进位),则不跳转,执行这一步,ax自加1(高位自加1)
ok: mov ax,4c00h ;结束
int 21h
code ends
end start
easy,唯一的点就是jnc。
科普一下,JNC就是CF为NC时跳转,JC就是CF为CY时跳转 本帖最后由 jackz007 于 2021-2-15 14:26 编辑
assume cs:code ; 编程计算1EF000H+201000H,结果放在ax(高16位)和bx(低16位)中。
code segment
start:mov ax,1Eh
mov bx,0F000H
add bx,1000H
adc ax,20h ; 根本就不用跳转那么麻烦,有一条指令叫 adc , 可以把 CF 的值直接加给指定寄存器,了解一下。
mov ax,4c00h
int 21h
code ends
end start jackz007 发表于 2021-2-15 14:20
感谢感谢,忘了还有个adc了,哈哈哈。
页:
[1]