1.加法

加法指令:ADD(Addition)
格式: ADD OPRD1,OPRD2
功能:两数相加,这两个数的类型可以为存储器,寄存器,立即数
不允许OPRD1和OPRD2同时为存储器
带进位加法指令ADC(Addition Carry)
格式:ADC OPRD1,OPRD2
功能:OPRD1=OPRD1+OPRD2+CF

 #include<stdio.h>
  main()
{
  int a;
	_asm{
	         mov eax,3
			 mov ebx,2
			 add eax,ebx
			 mov a,eax
	};
        printf("%d\n",a);  //结果为5
}

2.减法

减法指令SUB(SUBtract)
格式:SUB OPRD1,OPRD2
功能:OPRD1减去OPRD2,把值存在OPRD1中。
两个数的类型可以为存储器,寄存器,立即数
注意:
1.立即数不能用于目的操作数,
2.两个存储器操作数之间不能直接相减
3.操作数可为8位或16位的无符号数或带符号数
带借位减法指令SBB(SuBtraction with Borrow)
格式 :SBB OPRD1,OPRD2
功能:进行两个操作数的相减再减去CF进位标志位,即OPRD1=OPRD1-OPRD2-CF,其结果放在OPRD1中。

#include<stdio.h>
main(){
  int a;
	_asm{
	         mov eax,5
			 mov ebx,1
			 sub eax,ebx
			 mov a,eax
	};
   printf("%d\n",a);   //结果为4
}

3.乘法

无符号乘法指令MUL(MULtiply)
格式:MUL OPRD
带符号数乘法指令IMUL(Integer MULtiply)
格式:IMUL OPRD
OPRD为通用寄存器或存储器操作数
== 相当于给eax寄存器乘以一个数==
本指令影响标志位 CF及OF

#include<stdio.h>
main(){
  int a;
	_asm{
	         mov eax,3
			 mov ebx,2
			 mul ebx      //给eax寄存器乘以ebx,,若换成mul eax,输出结果为9
			 mov a,eax    //输出结果为6
	};
   printf("%d\n",a);
}

4.除法

无符号数除法指令DIV(DIVision)
格式:DIV OPRD
功能:实现两个无符号二进制数除法运算。
带符号数除法运算IDIV(Interger DIVision)
格式:IDIV OPRD
功能:实现两个带符号二进制数除法运算。
例如16bit的被除数,分存在2个8bit寄存器AH:AL,商放在AL,余数在AH
例如32bit的被除数,分存在2个16bit寄存器DX:AX,商放在AX,余数在DX
例如64bit的被除数,分存在2个32bit寄存器EDX:EAX,商放在EAX,余数在EDX
例如128bit的被除数,分存在2个64bit寄存器RDX:RAX,商放在RAX,余数在RDX

5.自增

加1指令 INC (INCrement by 1)
格式:INC OPRD
功能:OPRD=OPRD+1

#include<stdio.h>
main(){
  int a;
	_asm{
	         mov eax,10
			 inc eax
			 mov a,eax	
	};
   printf("%d\n",a); //输出结果为11
}

6.自减

减1指令DEC(DECrement by 1)
格式:DEC OPRD
功能:OPRD=OPRD-1

#include<stdio.h>
main(){
  int a;
	_asm{
	         mov eax,10
			 dec eax
			 mov a,eax	
	};
   printf("%d\n",a);   //结果为9
}
Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐