亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 堆和棧的區別.txt

?? 堆和棧的區別
?? TXT
?? 第 1 頁 / 共 3 頁
字號:
├———————┤ 
│ parameter 3 │ 
├———————┤<—“__stdcall”函數返回后的棧頂(ESP) 
│ …… │ 
├———————┤<—棧底(基地址 EBP)、高端內存區域 


上圖就是函數調用過程中堆棧的樣子了。首先,三個參數以從又到左的次序壓入堆棧,先壓“param3”,再壓“param2”,最后壓入“param1”;然后壓入函數的返回地址(RET),接著跳轉到函數地址接著執行(這里要補充一點,介紹UNIX下的緩沖溢出原理的文章中都提到在壓入RET后,繼續壓入當前EBP,然后用當前ESP代替EBP。然而,有一篇介紹windows下函數調用的文章中說,在windows下的函數調用也有這一步驟,但根據我的實際調試,并未發現這一步,這還可以從param3和var1之間只有4字節的間隙這點看出來);第三步,將棧頂(ESP)減去一個數,為本地變量分配內存空間,上例中是減去12字節(ESP=ESP-3*4,每個int變量占用4個字節);接著就初始化本地變量的內存空間。由于“__stdcall”調用由被調函數調整堆棧,所以在函數返回前要恢復堆棧,先回收本地變量占用的內存(ESP=ESP+3*4),然后取出返回地址,填入EIP寄存器,回收先前壓入參數占用的內存(ESP=ESP+3*4),繼續執行調用者的代碼。參見下列匯編代碼: 

;--------------func 函數的匯編代碼------------------- 

:00401000 83EC0C sub esp, 0000000C //創建本地變量的內存空間 
:00401003 8B442410 mov eax, dword ptr [esp+10] 
:00401007 8B4C2414 mov ecx, dword ptr [esp+14] 
:0040100B 8B542418 mov edx, dword ptr [esp+18] 
:0040100F 89442400 mov dword ptr [esp], eax 
:00401013 8D442410 lea eax, dword ptr [esp+10] 
:00401017 894C2404 mov dword ptr [esp+04], ecx 

……………………(省略若干代碼) 

:00401075 83C43C add esp, 0000003C ;恢復堆棧,回收本地變量的內存空間 
:00401078 C3 ret 000C ;函數返回,恢復參數占用的內存空間 
;如果是“__cdecl”的話,這里是“ret”,堆棧將由調用者恢復 

;-------------------函數結束------------------------- 


;--------------主程序調用func函數的代碼-------------- 

:00401080 6A03 push 00000003 //壓入參數param3 
:00401082 6A02 push 00000002 //壓入參數param2 
:00401084 6A01 push 00000001 //壓入參數param1 
:00401086 E875FFFFFF call 00401000 //調用func函數 
;如果是“__cdecl”的話,將在這里恢復堆棧,“add esp, 0000000C” 

聰明的讀者看到這里,差不多就明白緩沖溢出的原理了。先來看下面的代碼: 

#include <stdio.h> 
#include <string.h> 

void __stdcall func() 
{ 
char lpBuff[8]="\0"; 
strcat(lpBuff,"AAAAAAAAAAA"); 
return; 
} 

int main() 
{ 
func(); 
return 0; 
} 

編譯后執行一下回怎么樣?哈,“"0x00414141"指令引用的"0x00000000"內存。該內存不能為"read"。”,“非法操作”嘍!"41"就是"A"的16進制的ASCII碼了,那明顯就是strcat這句出的問題了。"lpBuff"的大小只有8字節,算進結尾的\0,那strcat最多只能寫入7個"A",但程序實際寫入了11個"A"外加1個\0。再來看看上面那幅圖,多出來的4個字節正好覆蓋了RET的所在的內存空間,導致函數返回到一個錯誤的內存地址,執行了錯誤的指令。如果能精心構造這個字符串,使它分成三部分,前一部份僅僅是填充的無意義數據以達到溢出的目的,接著是一個覆蓋RET的數據,緊接著是一段shellcode,那只要著個RET地址能指向這段shellcode的第一個指令,那函數返回時就能執行shellcode了。但是軟件的不同版本和不同的運行環境都可能影響這段shellcode在內存中的位置,那么要構造這個RET是十分困難的。一般都在RET和shellcode之間填充大量的NOP指令,使得exploit有更強的通用性。 


├———————┤<—低端內存區域 
│ …… │ 
├———————┤<—由exploit填入數據的開始 
│ │ 
│ buffer │<—填入無用的數據 
│ │ 
├———————┤ 
│ RET │<—指向shellcode,或NOP指令的范圍 
├———————┤ 
│ NOP │ 
│ …… │<—填入的NOP指令,是RET可指向的范圍 
│ NOP │ 
├———————┤ 
│ │ 
│ shellcode │ 
│ │ 
├———————┤<—由exploit填入數據的結束 
│ …… │ 
├———————┤<—高端內存區域 


windows下的動態數據除了可存放在棧中,還可以存放在堆中。了解C++的朋友都知道,C++可以使用new關鍵字來動態分配內存。來看下面的C++代碼: 

#include <stdio.h> 
#include <iostream.h> 
#include <windows.h> 

void func() 
{ 
char *buffer=new char[128]; 
char bufflocal[128]; 
static char buffstatic[128]; 
printf("0x%08x\n",buffer); //打印堆中變量的內存地址 
printf("0x%08x\n",bufflocal); //打印本地變量的內存地址 
printf("0x%08x\n",buffstatic); //打印靜態變量的內存地址 
} 

void main() 
{ 
func(); 
return; 
} 

程序執行結果為: 

0x004107d0 
0x0012ff04 
0x004068c0 

可以發現用new關鍵字分配的內存即不在棧中,也不在靜態數據區。VC編譯器是通過windows下的“堆(heap)”來實現new關鍵字的內存動態分配。在講“堆”之前,先來了解一下和“堆”有關的幾個API函數: 

HeapAlloc 在堆中申請內存空間 
HeapCreate 創建一個新的堆對象 
HeapDestroy 銷毀一個堆對象 
HeapFree 釋放申請的內存 
HeapWalk 枚舉堆對象的所有內存塊 
GetProcessHeap 取得進程的默認堆對象 
GetProcessHeaps 取得進程所有的堆對象 
LocalAlloc 
GlobalAlloc 

當進程初始化時,系統會自動為進程創建一個默認堆,這個堆默認所占內存的大小為1M。堆對象由系統進行管理,它在內存中以鏈式結構存在。通過下面的代碼可以通過堆動態申請內存空間: 

HANDLE hHeap=GetProcessHeap(); 
char *buff=HeapAlloc(hHeap,0,8); 

其中hHeap是堆對象的句柄,buff是指向申請的內存空間的地址。那這個hHeap究竟是什么呢?它的值有什么意義嗎?看看下面這段代碼吧: 

#pragma comment(linker,"/entry:main") //定義程序的入口 
#include <windows.h> 

_CRTIMP int (__cdecl *printf)(const char *, ...); //定義STL函數printf 
/*--------------------------------------------------------------------------- 
寫到這里,我們順便來復習一下前面所講的知識: 
(*注)printf函數是C語言的標準函數庫中函數,VC的標準函數庫由msvcrt.dll模塊實現。 
由函數定義可見,printf的參數個數是可變的,函數內部無法預先知道調用者壓入的參數個數,函數只能通過分析第一個參數字符串的格式來獲得壓入參數的信息,由于這里參數的個數是動態的,所以必須由調用者來平衡堆棧,這里便使用了__cdecl調用規則。BTW,Windows系統的API函數基本上是__stdcall調用形式,只有一個API例外,那就是wsprintf,它使用__cdecl調用規則,同printf函數一樣,這是由于它的參數個數是可變的緣故。 
---------------------------------------------------------------------------*/ 
void main() 
{ 
HANDLE hHeap=GetProcessHeap(); 
char *buff=HeapAlloc(hHeap,0,0x10); 
char *buff2=HeapAlloc(hHeap,0,0x10); 
HMODULE hMsvcrt=LoadLibrary("msvcrt.dll"); 
printf=(void *)GetProcAddress(hMsvcrt,"printf"); 
printf("0x%08x\n",hHeap); 
printf("0x%08x\n",buff); 
printf("0x%08x\n\n",buff2); 
} 

執行結果為: 

0x00130000 
0x00133100 
0x00133118 

hHeap的值怎么和那個buff的值那么接近呢?其實hHeap這個句柄就是指向HEAP首部的地址。在進程的用戶區存著一個叫PEB(進程環境塊)的結構,這個結構中存放著一些有關進程的重要信息,其中在PEB首地址偏移0x18處存放的ProcessHeap就是進程默認堆的地址,而偏移0x90處存放了指向進程所有堆的地址列表的指針。windows有很多API都使用進程的默認堆來存放動態數據,如windows 2000下的所有ANSI版本的函數都是在默認堆中申請內存來轉換ANSI字符串到Unicode字符串的。對一個堆的訪問是順序進行的,同一時刻只能有一個線程訪問堆中的數據,當多個線程同時有訪問要求時,只能排隊等待,這樣便造成程序執行效率下降。 

最后來說說內存中的數據對齊。所位數據對齊,是指數據所在的內存地址必須是該數據長度的整數倍,DWORD數據的內存起始地址能被4除盡,WORD數據的內存起始地址能被2除盡,x86 CPU能直接訪問對齊的數據,當他試圖訪問一個未對齊的數據時,會在內部進行一系列的調整,這些調整對于程序來說是透明的,但是會降低運行速度,所以編譯器在編譯程序時會盡量保證數據對齊。同樣一段代碼,我們來看看用VC、Dev-C++和lcc三個不同編譯器編譯出來的程序的執行結果: 

#include <stdio.h> 

int main() 
{ 
int a; 
char b; 
int c; 
printf("0x%08x\n",&a); 
printf("0x%08x\n",&b); 
printf("0x%08x\n",&c); 
return 0; 
} 

這是用VC編譯后的執行結果: 
0x0012ff7c 
0x0012ff7b 
0x0012ff80 
變量在內存中的順序:b(1字節)-a(4字節)-c(4字節)。 

這是用Dev-C++編譯后的執行結果: 
0x0022ff7c 
0x0022ff7b 
0x0022ff74 
變量在內存中的順序:c(4字節)-中間相隔3字節-b(占1字節)-a(4字節)。 

這是用lcc編譯后的執行結果: 
0x0012ff6c 
0x0012ff6b 
0x0012ff64 
變量在內存中的順序:同上。 

三個編譯器都做到了數據對齊,但是后兩個編譯器顯然沒VC“聰明”,讓一個char占了4字節,浪費內存哦。 


基礎知識: 
堆棧是一種簡單的數據結構,是一種只允許在其一端進行插入或刪除的線性表。允許插入或刪除操作的一端稱為棧頂,另一端稱為棧底,對堆棧的插入和刪除操作被稱為入棧和出棧。有一組CPU指令可以實現對進程的內存實現堆棧訪問。其中,POP指令實現出棧操作,PUSH指令實現入棧操作。CPU的ESP寄存器存放當前線程的棧頂指針,EBP寄存器中保存當前線程的棧底指針。CPU的EIP寄存器存放下一個CPU指令存放的內存地址,當CPU執行完當前的指令后,從EIP寄存器中讀取下一條指令的內存地址,然后繼續執行。 


參考:《Windows下的HEAP溢出及其利用》by: isno 
《windows核心編程》by: Jeffrey Richter 





摘要: 討論常見的堆性能問題以及如何防范它們。(共 9 頁)

前言
您是否是動態分配的 C/C++ 對象忠實且幸運的用戶?您是否在模塊間的往返通信中頻繁地使用了“自動化”?您的程序是否因堆分配而運行起來很慢?不僅僅您遇到這樣的問題。幾乎所有項目遲早都會遇到堆問題。大家都想說,“我的代碼真正好,只是堆太慢”。那只是部分正確。更深入理解堆及其用法、以及會發生什么問題,是很有用的。

什么是堆?
(如果您已經知道什么是堆,可以跳到“什么是常見的堆性能問題?”部分)

在程序中,使用堆來動態分配和釋放對象。在下列情況下,調用堆操作: 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区久久| 久久久久9999亚洲精品| av激情亚洲男人天堂| 激情综合网最新| 狠狠色综合日日| 精品一区二区免费视频| 精品午夜久久福利影院| 精品一区二区在线免费观看| 看国产成人h片视频| 美女一区二区久久| 国产自产视频一区二区三区 | 粉嫩aⅴ一区二区三区四区五区| 精品影视av免费| 成人一级黄色片| 91免费小视频| 这里只有精品视频在线观看| 欧美一级高清大全免费观看| 精品久久久三级丝袜| 久久夜色精品国产欧美乱极品| 国产清纯美女被跳蛋高潮一区二区久久w| 久久久亚洲高清| 亚洲人被黑人高潮完整版| 亚洲综合小说图片| 国产成人精品免费看| 成人免费视频播放| 色偷偷久久人人79超碰人人澡| 欧美综合在线视频| 精品久久人人做人人爰| 中文字幕中文字幕一区二区| 亚洲国产视频一区二区| 黄页视频在线91| 色综合av在线| 久久午夜羞羞影院免费观看| 亚洲欧洲av一区二区三区久久| 午夜精品久久久久影视| 久久99精品久久久久久动态图| jlzzjlzz欧美大全| 5566中文字幕一区二区电影| 久久久www成人免费无遮挡大片| 国产精品久久久久aaaa樱花| 无码av免费一区二区三区试看| 精品一区二区三区免费毛片爱 | 成人高清视频在线观看| 欧美三级视频在线| 欧美国产精品一区二区三区| 亚洲福利一二三区| 成人va在线观看| 日韩欧美一二区| 亚洲一区中文在线| www.日本不卡| 日韩精品一区二区三区蜜臀| 亚洲色图视频网站| 国产99久久久国产精品潘金网站| 69堂精品视频| 亚洲国产精品久久久久秋霞影院 | 欧美日韩一区二区三区四区五区| 国产午夜精品一区二区| 美女免费视频一区| 欧美日韩综合不卡| 一区二区三区四区在线免费观看 | 亚洲精品国产视频| 欧美剧情片在线观看| 综合自拍亚洲综合图不卡区| 国精产品一区一区三区mba视频 | 91精品国产综合久久精品图片| 中文字幕一区二区三区乱码在线| 韩国v欧美v亚洲v日本v| 欧美一级生活片| 日韩va欧美va亚洲va久久| 欧美性欧美巨大黑白大战| 中文字幕在线不卡一区二区三区| 国产成人综合网| 国产日韩欧美精品综合| 国产成人av网站| 久久综合狠狠综合| 国产一区二区三区观看| 久久久精品一品道一区| 国产综合色视频| 中文字幕不卡在线| 99久久综合国产精品| 亚洲六月丁香色婷婷综合久久| 91麻豆国产在线观看| 亚洲品质自拍视频| 欧美在线观看一区| 婷婷开心久久网| 欧美一区二区三区视频免费| 欧美aⅴ一区二区三区视频| 91麻豆精品国产91久久久更新时间| 亚洲一区二区三区在线看| 在线观看一区二区精品视频| 亚洲电影一级黄| 日韩亚洲欧美在线| 成人网在线免费视频| 亚洲少妇最新在线视频| 欧美日韩亚洲综合| 久久国内精品自在自线400部| 久久婷婷国产综合国色天香 | 国产精品久久一级| 在线一区二区三区四区| 免费精品视频最新在线| 国产婷婷色一区二区三区 | 欧美三片在线视频观看| 免费日韩伦理电影| 国产精品日日摸夜夜摸av| 欧美日韩免费一区二区三区视频| 国产盗摄视频一区二区三区| 成人免费在线播放视频| 在线观看91视频| 国产乱码精品一区二区三区五月婷| 中文字幕欧美三区| 欧美另类z0zxhd电影| 国产iv一区二区三区| 亚洲一区自拍偷拍| 欧美国产日韩亚洲一区| 欧美日韩1234| 成人在线一区二区三区| 免费在线观看一区| 亚洲三级久久久| 久久午夜色播影院免费高清 | 国产麻豆9l精品三级站| 亚洲精品第1页| 国产亚洲精品超碰| 欧美群妇大交群的观看方式 | 亚洲蜜臀av乱码久久精品蜜桃| 91精品国产综合久久精品图片| 成人a区在线观看| 久久精品国产在热久久| 亚洲美女视频在线| 欧美极品xxx| 欧美xxxxxxxx| 欧美日韩在线播放一区| 99久久精品国产一区| 国内精品国产成人国产三级粉色 | 欧美日韩成人一区| 99精品黄色片免费大全| 国产成人在线电影| 久久国产生活片100| 香蕉av福利精品导航| 亚洲欧美一区二区视频| 国产午夜一区二区三区| 日韩精品一区二区三区swag| 欧美日韩大陆在线| 在线观看欧美日本| 91久久一区二区| 色噜噜久久综合| 91国在线观看| 欧美做爰猛烈大尺度电影无法无天| av在线一区二区| 成人av网站在线观看免费| 国产电影一区二区三区| 国产精品综合在线视频| 国产精品一区二区在线观看不卡| 久久av老司机精品网站导航| 日韩不卡免费视频| 久久精品国产久精国产| 久色婷婷小香蕉久久| 精品一区二区在线免费观看| 美女视频免费一区| 久久99久国产精品黄毛片色诱| 另类小说综合欧美亚洲| 国产尤物一区二区在线| 国产成人综合网站| av不卡免费在线观看| 色婷婷一区二区| 欧美日韩亚洲综合在线| 日韩精品影音先锋| 国产视频一区二区在线| 亚洲欧美日韩中文播放 | 久久国产精品无码网站| 麻豆91在线观看| 国产精品一区二区你懂的| 国产suv精品一区二区三区| 处破女av一区二区| 在线一区二区三区| 日韩欧美一级二级三级| 中文字幕乱码亚洲精品一区| 亚洲三级在线观看| 日韩高清在线电影| 国产精品中文字幕日韩精品 | 国产成人精品亚洲777人妖| 99精品久久免费看蜜臀剧情介绍| 在线免费观看日本一区| 91精品国产综合久久精品图片 | 欧美无人高清视频在线观看| 欧美一卡二卡三卡| 国产精品嫩草影院av蜜臀| 亚洲成人精品一区| 国产成人自拍网| 精品视频123区在线观看| 久久久国产综合精品女国产盗摄| 国产精品进线69影院| 日韩国产在线一| 成人激情免费视频| 欧美一二三区在线| 亚洲欧美一区二区三区孕妇| 日本亚洲天堂网| 91免费在线播放| 国产午夜精品一区二区三区嫩草| 亚洲视频在线观看三级| 国产在线精品视频|