滴水逆向_学习笔记

滴水逆向第三期学习笔记


LEA指令

<h3>LEA指令</h3> <p>LEA是微机8086/8088系列的一条指令,取自英语Load effect address——取有效地址,也就是取偏移地址。在微机8086/8088中有20位物理地址,由16位段基址向左偏移4位再与偏移地址之和得到。地址传送指令之一。</p> <h3>取偏移地址指令</h3> <h5>指令格式如下:</h5> <p><code>LEA reg16,mem</code></p> <p>LEA指令将存储器操作数mem的4位16进制偏移地址送到指定的寄存器。这里,源操作数必须是存储器操作数,目标操作数必须是16位通用寄存器。因该寄存器常用来作为地址指针,故在此最好选用四个间址寄存器BX,BP,SI,DI之一。</p> <h3>LEA 取有效地址指令 (Load Effective Address )</h3> <h5>指令格式:<code>LEA 目的,源</code></h5> <h5>指令功能:取源操作数地址的偏移量,并把它传送到目的操作数所在的单元。如:</h5> <p><code>LEA BX ,BUFFER</code></p> <p><code>LEA AX,[BX][DI]</code>(j基址加变址寻址)</p> <p><code>LEA DX,DATA [BX][SI]</code>(相对基址加变址寻址)[1] </p> <p>LEA 指令要求源操作数必须是存储单元,而且目的操作数必须是一个除段寄存器之外的16位或32位寄存器。当目的操作数是16位通用寄存器时,那么只装入有效地址的低16位。使用时要注意它与MOV指令的区别,MOV指令传送的一般是源操作数中的内容而不是地址。</p> <p>例1 假设:<code>SI=1000H , DS=5000H, (51000H)=1234H</code></p> <p>执行指令 <code>LEA BX</code> , [SI]后,BX=1000H</p> <p>执行指令 <code>MOV BX</code> , [SI]后,BX=1234H</p> <p>有时,LEA指令也可用取偏移地址的MOV指令替代。</p> <p>例2 下面两条指令就是等价的,他们都取TABLE的偏移地址,然后送到BX中,即</p> <p><code>LEA BX,TABLE</code></p> <p><code>MOV BX,OFFSET TABLE</code></p> <p>但有些时候,必须使用LEA指令来完成某些功能,不能用MOV指令来实现,必须使用下面指令:</p> <p><code>LEA BX, 6[DI]</code></p> <p>解释:某数组含20个元素,每个元素占一个字节,序号为0~19。设DI指向数组开头处,如果把序号为6的元素的偏移地址送到BX中</p> <hr /> <hr /> <p>官方解释Load Effective Address,即装入有效地址的意思,它的操作数就是地址;</p> <p>常见的几种用法:</p> <h4>1、`lea eax``,[addr]</h4> <h4>就是将表达式addr的值放入eax寄存器,</h4> <p>示例如下:</p> <p><code>lea eax,[401000h]</code>; 将值401000h写入eax寄存器中</p> <p>lea指令右边的操作数表示一个精指针,上述指令和mov eax,401000h是等价的</p> <h4>2、<code>lea eax</code>,dword ptr [ebx];将ebx的值赋值给eax</h4> <h4>3、<code>lea eax</code>,c;其中c为一个int型的变量,该条语句的意思是把c的地址赋值给eax;</h4> <h4>编个程序验证一下:</h4> <pre><code class="language-c">#include&lt;iostream&gt; using namespace std; int main() { int a=400000, b = 5; int c, d; __asm { mov eax, 2 lea ebx, dword ptr[eax] mov c, ebx; lea ebx, c; mov eax, [ebx]; mov d, eax; } printf("c=%d,d=%d\n", c,d); return 0; }</code></pre> <p><img src="https://www.showdoc.com.cn/server/api/attachment/visitfile/sign/a16c7daa2b1006d6861ccfe2e2720239" alt="" /></p>

页面列表

ITEM_HTML