rep stos dword ptr es:[edi]
本文鏈接:https://blog.csdn.net/ypist/article/details/8467163
今天讀代碼時(shí),忽然跳出如下一條指令==>>
匯編代碼: rep stos dword ptr es:[edi]
在網(wǎng)上查了相關(guān)資料顯示:
/************************************************************/
lea edi,[ebp-0C0h]
mov ecx,30h
mov eax,0CCCCCCCCh
rep stos dword ptr es:[edi]
rep指令的目的是重復(fù)其上面的指令.ECX的值是重復(fù)的次數(shù).
STOS指令的作用是將eax中的值拷貝到ES:EDI指向的地址.
如果設(shè)置了direction flag, 那么edi會(huì)在該指令執(zhí)行后減小,
如果沒(méi)有設(shè)置direction flag, 那么edi的值會(huì)增加.
REP可以是任何字符傳指令(CMPS, LODS, MOVS, SCAS, STOS)的前綴.
REP能夠引發(fā)其后的字符串指令被重復(fù), 只要ecx的值不為0, 重復(fù)就會(huì)繼續(xù).
每一次字符串指令執(zhí)行后, ecx的值都會(huì)減小.
stos((store into String),意思是把eax的內(nèi)容拷貝到目的地址。
用法:stos dst,dst是一個(gè)目的地址,例如:stos dword ptr es:[edi]。dword ptr前綴告訴stos,一次拷貝雙字(4個(gè)字節(jié))的數(shù)據(jù)到目的地址。為什么一次非要拷貝雙字呢?這和eax寄存器有關(guān),到底神馬關(guān)系,慢慢道來(lái)。。
執(zhí)行stos之前必須往eax(32為寄存器)放入要拷貝的數(shù)據(jù)。上圖中,eax的內(nèi)容是cccccccc,不用說(shuō)都明白int3中斷。
這段代碼是初始化堆棧和分配局部變量用的,往分配好的局部變量空間放入int3中斷的原因是:防止該空間里的東東被意外執(zhí)行。
/************************************************************/
想了想,沒(méi)怎么明白,于是直接寫(xiě)了個(gè)函數(shù),來(lái)加深一下印象:
/************************************************************/
#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
}
是沒(méi)有任何作用的,只是為了讓我們?cè)诜磪R編時(shí)好定位代碼的位置。
---------------------
版權(quán)聲明:本文為CSDN博主「pinggle」的原創(chuàng)文章,遵循CC 4.0 by-sa版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/ypist/article/details/8467163
總結(jié)
以上是生活随笔為你收集整理的rep stos dword ptr es:[edi]的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 一体化防爆气象仪:一种多个参数监测的防爆
- 下一篇: Java 2 个 List 集合数据求并