汇编语言的ADC和ADD怎么理解
2个回答
展开全部
ADD是普通的加法指令,ADC是带进位的加法指令。
两者的格式都为:
ADD/ADC source,destination
将源操作数的值与目标操作数的值相加,并将运算结果放在目标操作数指示的位置。并根据相加结果设置标志寄存器的CF,PF,AF,ZF,SF,OF。
唯一的不同是,ADC执行加法运算时,会将CF位的值一起加到目标操作数中。所以ADC常用于处理以下情况:
如果必须处理非常大的、不能存放到双字数据长度(ADD可以使用的最大长度)中的整数,可以把值分割为多个双字数据元素,并且对每个元素执行独立的加法操作。
为了正确完成这个操作,必须检测每个加法操作的进位标志,如果进位标志被设置为1,就必须进位到下一对相加的数据元素。
ADC指令执行两个无符号或者带符号整数值的加法,并且把前一个ADD指令产生的进位标志的值包含在其中。ADC指令也按照操作结果正确地设置进位和溢出标志。
两者的格式都为:
ADD/ADC source,destination
将源操作数的值与目标操作数的值相加,并将运算结果放在目标操作数指示的位置。并根据相加结果设置标志寄存器的CF,PF,AF,ZF,SF,OF。
唯一的不同是,ADC执行加法运算时,会将CF位的值一起加到目标操作数中。所以ADC常用于处理以下情况:
如果必须处理非常大的、不能存放到双字数据长度(ADD可以使用的最大长度)中的整数,可以把值分割为多个双字数据元素,并且对每个元素执行独立的加法操作。
为了正确完成这个操作,必须检测每个加法操作的进位标志,如果进位标志被设置为1,就必须进位到下一对相加的数据元素。
ADC指令执行两个无符号或者带符号整数值的加法,并且把前一个ADD指令产生的进位标志的值包含在其中。ADC指令也按照操作结果正确地设置进位和溢出标志。
展开全部
从字面上理解:
add - 这个不用说了,就是加的意思,2个数相加。
adc - add with carriage,就是带进位的加法。如果在本指令之前的运结果,有进位的话,那么adc除了把参加运算的2个数相加之外,还加上这个进位的数。
举例:
mov bl, 1
add al, 0FFH ;肯定有进位,进位值是1,状态寄存器有标识
adc bl, 2 ; 除了进行(bl)+2=3之外,还要加上前面指令进位1,所以结果是4
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询