rep stos dword ptr es:[edi]
本文鏈接:https://blog.csdn.net/ypist/article/details/8467163
今天讀代碼時,忽然跳出如下一條指令==>>
匯編代碼: rep stos dword ptr es:[edi]
在網上查了相關資料顯示:
/************************************************************/
lea edi,[ebp-0C0h]
mov ecx,30h
mov eax,0CCCCCCCCh
rep stos dword ptr es:[edi]
rep指令的目的是重復其上面的指令.ECX的值是重復的次數.
STOS指令的作用是將eax中的值拷貝到ES:EDI指向的地址.
如果設置了direction flag, 那么edi會在該指令執行后減小,
如果沒有設置direction flag, 那么edi的值會增加.
REP可以是任何字符傳指令(CMPS, LODS, MOVS, SCAS, STOS)的前綴.
REP能夠引發其后的字符串指令被重復, 只要ecx的值不為0, 重復就會繼續.
每一次字符串指令執行后, ecx的值都會減小.
stos((store into String),意思是把eax的內容拷貝到目的地址。
用法:stos dst,dst是一個目的地址,例如:stos dword ptr es:[edi]。dword ptr前綴告訴stos,一次拷貝雙字(4個字節)的數據到目的地址。為什么一次非要拷貝雙字呢?這和eax寄存器有關,到底神馬關系,慢慢道來。。
執行stos之前必須往eax(32為寄存器)放入要拷貝的數據。上圖中,eax的內容是cccccccc,不用說都明白int3中斷。
這段代碼是初始化堆棧和分配局部變量用的,往分配好的局部變量空間放入int3中斷的原因是:防止該空間里的東東被意外執行。
/************************************************************/
想了想,沒怎么明白,于是直接寫了個函數,來加深一下印象:
/************************************************************/
#include <stdio.h>
int main()
{
int i;
int result=0;
_asm{
mov edi,edi
mov edi,edi
}
for (i=0;i<20;++i)
result+=2;
return result;
}
/************************************************************/
其中,
_asm{
mov edi,edi
mov edi,edi
}
是沒有任何作用的,只是為了讓我們在反匯編時好定位代碼的位置。
---------------------
版權聲明:本文為CSDN博主「pinggle」的原創文章,遵循CC 4.0 by-sa版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/ypist/article/details/8467163
總結
以上是生活随笔為你收集整理的rep stos dword ptr es:[edi]的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一体化防爆气象仪:一种多个参数监测的防爆
- 下一篇: 选择合适的隔膜压力表:关键因素和决策指南