LEA指令与MOV指令区别

Tips:

LEA指令与MOV指令的区别:

MOV指令是 数据        传送指令-------传送数据

LEA指令是   有效地址 传送指令-------取偏移地址

MOV OPRD1 OPRD2

OPRD1: 目的操作数(寄存器,存储器,累加器)

OPRD2: 源操作数(寄存器,存储器,累加器,立即数)

例如:

1 MOV DI,BX  ;寄存器到寄存器之间传数
1 MOV AL,23H ;将立即数"复制"到寄存器
1 MOV [2000H],02H ;直接地址

注意:

目的操作数要与源操作数类型一致,不能一个字一个字节

目的或者源操作数之一必须是要有明确的类型

立即数不能作为目的操作数

不能用立即寻址的方法给段寄存器传数

段寄存器or存储单元之间 不能用MOV指令直接传送

----------------------------------------------我是华丽的分割线--------------------------------------------

LEA OPRD1,OPRD2  ;格式

OPRD1: 目的操作数,可为任意一个16位的通用寄存器

OPRD2:源操作数(变量名,标号,地址表达式)

例如:

1 LEA AX,[BX+123] ;BX的内容加上123并把它送到寄存器AX
1 LEA BX,data
1 LEA AX,[1234H] ;作用是将源操作数[1234H]的偏移地址送到AX
2 ;等价于
3 MOV AX,1234H

原文地址:https://www.cnblogs.com/roseAT/p/10080756.html

时间: 2024-12-10 10:48:11

LEA指令与MOV指令区别的相关文章

LEA指令与MOV指令的区别

一.汇编语言中PTR的含义及作用mov ax,bx ;是把BX寄存器"里"的值赋予AX,由于二者都是word型,所以没有必要加"WORD"mov ax,word ptr [bx];是把内存地址等于"BX寄存器的值"的地方所存放的数据,赋予ax.由于只是给出一个内存地址,不知道希望赋予ax的,是byte还是word,所以需要用word明确指出! 所以,当两个操作数的宽度不一样时,就要用到ptr.也就是说*p 用汇编表示就是:dword ptr [p

汇编Lea 指令与 Mov 指令

比如你用local在栈上定义了一个局部变量LocalVar,你知道实际的指令是什么么?一般都差不多像下面的样子:     push   ebp     mov   esp,   ebp     sub   esp,   4     现在栈上就有了4各字节的空间,这就是你的局部变量.     接下来,你执行mov   LocalVar,   4,那么实际的指令又是什么?是这样:     mov   dword   ptr   [ebp-4],   4     于是,这个局部变量的“地址”就是ebp

汇编语言学习:汇编指令:MOV指令

MOV指令为双操作数指令,两个操作数中不能全为内存操作数 格式:MOV DST,SRC 执行操作:dst <= src 注:1.目的数可以是通用寄存器,存储单元和段寄存器(但不允许用CS段寄存器). 2.立即数不能直接送段寄存器 3.不允许在两个存储单元直接传送数据 4.不允许在两个段寄存器间直接传送信息

汇编中中括号[]作用以及lea和mov指令的区别

现在总结一下:其中牵扯到lea指令,mov指令,[] 一.lea指令:对于寄存器来说:第二个操作数是寄存器必须要加[],不然报错,这里lea就是取[寄存器]的值,如:mov eax,2lea ebx,[eax];执行后ebx=2mov ebx,eax;等同于上句lea ebx,eax;编译器报错: error A2070: invalid instruction operands 对于变量来说加不加[]都是一样的效果,都是取变量的地址,相当于指针如:num dword 2lea ebx,numl

汇编语言中LEA与MOV指令小结

 LEA指令的功能是取偏移地址,MOV指令的功能是传送数据  LEA AX,[1000H],作用是将内存单元[1000H]的偏移地址1000H送至AX: MOV AX,[1000H],作用是将内存单元[1000H]的内容1234H送给AX LEA AX,[SI],作用是将寄存器SI的内容4567H当做数据传送给AX: MOV AX,[SI],作用是将寄存器SI的内容4567H当做地址看待,将地址为4567H处的内容传送给AX: LEA AX,SI,作用是将寄存器SI的偏移地址1001H传送给AX

arm指令中mov和ldr的区别

ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令. 比如想把数据从内存中某处读取到寄存器中,只能使用ldr 比如: ldr r0, 0x12345678 就是把0x12345678这个地址中的值存放到r0中. 而mov不能干这个活,mov只能在寄存器之间移动数据,或者把立即数移动到寄存器中,这个和x86这种CISC架构的芯片区别最大的地方. x86中没有ldr这种指令,因为x86的mov指令可以将数据从内存中移动到寄存器中. 另外还有一个就是l

ARM指令和Thumb指令区别

Thumb指令集 Thumb指令可以看做是ARM指令压缩形式的子集,是针对代码密度[1]的问题而提出的,它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序只执行Thumb指令而不支持ARM指令集.因此,Thumb指令只需要支持通用功能,必要时,可借助完善的ARM指令集,例如:所有异常自动进入ARM状态. 在编写Thumb指令时,先要使用伪指令CODE16声明,而且在ARM指令中要使用BX指令跳转到Thumb指令,以切换处理器状态.编写ARM指令时,可使用伪指令CODE32

基于8086CPU微处理器的汇编学习之MOV指令

汇编指令:MOV的作用是往某个寄存器中存入数值. 格式:mov  寄存器名,数值                数值-->寄存器 mov  寄存器A,存器寄B          B-->A PS:必须前后位数匹配,如: mov   ah,bx     ;error   ah is 8 bit,bx is 16 bit mov   ah, bh    ;right    ah and bh all is 8  bit mov   cx,dx     ;right     cx and dx al

JSP中的编译指令和动作指令的区别

JSP中的编译指令和动作指令的区别 1.编译指令是通知Servlet引擎的处理消息,而动作指令只是运行时的脚本动作 2.编译指令是在将JSP编译成Servlet时起作用,而动作指令可替换成JSP脚本,是JSP脚本标准化写法