日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

用VC写Assembly代码(6)--附录2[windows进程中的内存结构]

發布時間:2025/3/15 windows 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用VC写Assembly代码(6)--附录2[windows进程中的内存结构] 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在閱讀本文之前,如果你連堆棧是什么多不知道的話,請先閱讀文章后面的基礎知識。?

接觸過編程的人都知道,高級語言都能通過變量名來訪問內存中的數據。那么這些變量在內存中是如何存放的呢?程序又是如何使用這些變量的呢?下面就會對此進行深入的討論。下文中的C語言代碼如沒有特別聲明,默認都使用VC編譯的release版。?

首先,來了解一下?C?語言的變量是如何在內存分部的。C?語言有全局變量(Global)、本地變量(Local),靜態變量(Static)、寄存器變量(Regeister)。每種變量都有不同的分配方式。先來看下面這段代碼:?

#include?<stdio.h>?

int?g1=0,?g2=0,?g3=0;?

int?main()?
{?
static?int?s1=0,?s2=0,?s3=0;?
int?v1=0,?v2=0,?v3=0;?

//打印出各個變量的內存地址?

printf("0x%08x/n",&v1);?//打印各本地變量的內存地址?
printf("0x%08x/n",&v2);?
printf("0x%08x/n/n",&v3);?
printf("0x%08x/n",&g1);?//打印各全局變量的內存地址?
printf("0x%08x/n",&g2);?
printf("0x%08x/n/n",&g3);?
printf("0x%08x/n",&s1);?//打印各靜態變量的內存地址?
printf("0x%08x/n",&s2);?
printf("0x%08x/n/n",&s3);?
return?0;?
}?

編譯后的執行結果是:?

0x0012ff78?
0x0012ff7c?
0x0012ff80?

0x004068d0?
0x004068d4?
0x004068d8?

0x004068dc?
0x004068e0?
0x004068e4?

輸出的結果就是變量的內存地址。其中v1,v2,v3是本地變量,g1,g2,g3是全局變量,s1,s2,s3是靜態變量。你可以看到這些變量在內存是連續分布的,但是本地變量和全局變量分配的內存地址差了十萬八千里,而全局變量和靜態變量分配的內存是連續的。這是因為本地變量和全局/靜態變量是分配在不同類型的內存區域中的結果。對于一個進程的內存空間而言,可以在邏輯上分成3個部份:代碼區,靜態數據區和動態數據區。動態數據區一般就是“堆棧”。“棧(stack)”和“堆(heap)”是兩種不同的動態數據區,棧是一種線性結構,堆是一種鏈式結構。進程的每個線程都有私有的“棧”,所以每個線程雖然代碼一樣,但本地變量的數據都是互不干擾。一個堆棧可以通過“基地址”和“棧頂”地址來描述。全局變量和靜態變量分配在靜態數據區,本地變量分配在動態數據區,即堆棧中。程序通過堆棧的基地址和偏移量來訪問本地變量。?


├———————┤低端內存區域?
│?……?│?
├———————┤?
│?動態數據區?│?
├———————┤?
│?……?│?
├———————┤?
│?代碼區?│?
├———————┤?
│?靜態數據區?│?
├———————┤?
│?……?│?
├———————┤高端內存區域?


堆棧是一個先進后出的數據結構,棧頂地址總是小于等于棧的基地址。我們可以先了解一下函數調用的過程,以便對堆棧在程序中的作用有更深入的了解。不同的語言有不同的函數調用規定,這些因素有參數的壓入規則和堆棧的平衡。windows?API的調用規則和ANSI?C的函數調用規則是不一樣的,前者由被調函數調整堆棧,后者由調用者調整堆棧。兩者通過“__stdcall”和“__cdecl”前綴區分。先看下面這段代碼:?

#include?<stdio.h>?

void?__stdcall?func(int?param1,int?param2,int?param3)?
{?
int?var1=param1;?
int?var2=param2;?
int?var3=param3;?
printf("0x%08x/n",?m1);?//打印出各個變量的內存地址?
printf("0x%08x/n",?m2);?
printf("0x%08x/n/n",?m3);?
printf("0x%08x/n",&var1);?
printf("0x%08x/n",&var2);?
printf("0x%08x/n/n",&var3);?
return;?
}?

int?main()?
{?
func(1,2,3);?
return?0;?
}?

編譯后的執行結果是:?

0x0012ff78?
0x0012ff7c?
0x0012ff80?

0x0012ff68?
0x0012ff6c?
0x0012ff70?


├———————┤<—函數執行時的棧頂(ESP)、低端內存區域?
│?……?│?
├———————┤?
│?var?1?│?
├———————┤?
│?var?2?│?
├———————┤?
│?var?3?│?
├———————┤?
│?RET?│?
├———————┤<—“__cdecl”函數返回后的棧頂(ESP)?
│?parameter?1?│?
├———————┤?
│?parameter?2?│?
├———————┤?
│?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++?對象忠實且幸運的用戶?您是否在模塊間的往返通信中頻繁地使用了“自動化”?您的程序是否因堆分配而運行起來很慢?不僅僅您遇到這樣的問題。幾乎所有項目遲早都會遇到堆問題。大家都想說,“我的代碼真正好,只是堆太慢”。那只是部分正確。更深入理解堆及其用法、以及會發生什么問題,是很有用的。

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

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

事先不知道程序所需對象的數量和大小。


對象太大而不適合堆棧分配程序。
堆使用了在運行時分配給代碼和堆棧的內存之外的部分內存。下圖給出了堆分配程序的不同層。


此主題相關圖片如下:


GlobalAlloc/GlobalFree:Microsoft?Win32?堆調用,這些調用直接與每個進程的默認堆進行對話。

LocalAlloc/LocalFree:Win32?堆調用(為了與?Microsoft?Windows?NT?兼容),這些調用直接與每個進程的默認堆進行對話。

COM?的?IMalloc?分配程序(或?CoTaskMemAlloc?/?CoTaskMemFree):函數使用每個進程的默認堆。自動化程序使用“組件對象模型?(COM)”的分配程序,而申請的程序使用每個進程堆。

C/C++?運行時?(CRT)?分配程序:提供了?malloc()?和?free()?以及?new?和?delete?操作符。如?Microsoft?Visual?Basic?和?Java?等語言也提供了新的操作符并使用垃圾收集來代替堆。CRT?創建自己的私有堆,駐留在?Win32?堆的頂部。

Windows?NT?中,Win32?堆是?Windows?NT?運行時分配程序周圍的薄層。所有?API?轉發它們的請求給?NTDLL。

Windows?NT?運行時分配程序提供?Windows?NT?內的核心堆分配程序。它由具有?128?個大小從?8?到?1,024?字節的空閑列表的前端分配程序組成。后端分配程序使用虛擬內存來保留和提交頁。

在圖表的底部是“虛擬內存分配程序”,操作系統使用它來保留和提交頁。所有分配程序使用虛擬內存進行數據的存取。

分配和釋放塊不就那么簡單嗎?為何花費這么長時間?

堆實現的注意事項
傳統上,操作系統和運行時庫是與堆的實現共存的。在一個進程的開始,操作系統創建一個默認堆,叫做“進程堆”。如果沒有其他堆可使用,則塊的分配使用“進程堆”。語言運行時也能在進程內創建單獨的堆。(例如,C?運行時創建它自己的堆。)除這些專用的堆外,應用程序或許多已載入的動態鏈接庫?(DLL)?之一可以創建和使用單獨的堆。Win32?提供一整套?API?來創建和使用私有堆。有關堆函數(英文)的詳盡指導,請參見?MSDN。

當應用程序或?DLL?創建私有堆時,這些堆存在于進程空間,并且在進程內是可訪問的。從給定堆分配的數據將在同一個堆上釋放。(不能從一個堆分配而在另一個堆釋放。)

在所有虛擬內存系統中,堆駐留在操作系統的“虛擬內存管理器”的頂部。語言運行時堆也駐留在虛擬內存頂部。某些情況下,這些堆是操作系統堆中的層,而語言運行時堆則通過大塊的分配來執行自己的內存管理。不使用操作系統堆,而使用虛擬內存函數更利于堆的分配和塊的使用。

典型的堆實現由前、后端分配程序組成。前端分配程序維持固定大小塊的空閑列表。對于一次分配調用,堆嘗試從前端列表找到一個自由塊。如果失敗,堆被迫從后端(保留和提交虛擬內存)分配一個大塊來滿足請求。通用的實現有每塊分配的開銷,這將耗費執行周期,也減少了可使用的存儲空間。

Knowledge?Base?文章?Q10758,“用?calloc()?和?malloc()?管理內存”?(搜索文章編號),?包含了有關這些主題的更多背景知識。另外,有關堆實現和設計的詳細討論也可在下列著作中找到:“Dynamic?Storage?Allocation:?A?Survey?and?Critical?Review”,作者?Paul?R.?Wilson、Mark?S.?Johnstone、Michael?Neely?和?David?Boles;“International?Workshop?on?Memory?Management”,?作者?Kinross,?Scotland,?UK,?1995?年?9?月(http://www.cs.utexas.edu/users/oops/papers.html)(英文)。

Windows?NT?的實現(Windows?NT?版本?4.0?和更新版本)?使用了?127?個大小從?8?到?1,024?字節的?8?字節對齊塊空閑列表和一個“大塊”列表。“大塊”列表(空閑列表[0])?保存大于?1,024?字節的塊。空閑列表容納了用雙向鏈表鏈接在一起的對象。默認情況下,“進程堆”執行收集操作。(收集是將相鄰空閑塊合并成一個大塊的操作。)收集耗費了額外的周期,但減少了堆塊的內部碎片。

單一全局鎖保護堆,防止多線程式的使用。(請參見“Server?Performance?and?Scalability?Killers”中的第一個注意事項,?George?Reilly?所著,在?“MSDN?Online?Web?Workshop”上(站點:http://msdn.microsoft.com/workshop/server/iis/tencom.asp(英文)。)單一全局鎖本質上是用來保護堆數據結構,防止跨多線程的隨機存取。若堆操作太頻繁,單一全局鎖會對性能有不利的影響。

什么是常見的堆性能問題?
以下是您使用堆時會遇到的最常見問題:?

分配操作造成的速度減慢。光分配就耗費很長時間。最可能導致運行速度減慢原因是空閑列表沒有塊,所以運行時分配程序代碼會耗費周期尋找較大的空閑塊,或從后端分配程序分配新塊。


釋放操作造成的速度減慢。釋放操作耗費較多周期,主要是啟用了收集操作。收集期間,每個釋放操作“查找”它的相鄰塊,取出它們并構造成較大塊,然后再把此較大塊插入空閑列表。在查找期間,內存可能會隨機碰到,從而導致高速緩存不能命中,性能降低。


堆競爭造成的速度減慢。當兩個或多個線程同時訪問數據,而且一個線程繼續進行之前必須等待另一個線程完成時就發生競爭。競爭總是導致麻煩;這也是目前多處理器系統遇到的最大問題。當大量使用內存塊的應用程序或?DLL?以多線程方式運行(或運行于多處理器系統上)時將導致速度減慢。單一鎖定的使用—常用的解決方案—意味著使用堆的所有操作是序列化的。當等待鎖定時序列化會引起線程切換上下文。可以想象交叉路口閃爍的紅燈處走走停停導致的速度減慢。?
競爭通常會導致線程和進程的上下文切換。上下文切換的開銷是很大的,但開銷更大的是數據從處理器高速緩存中丟失,以及后來線程復活時的數據重建。

堆破壞造成的速度減慢。造成堆破壞的原因是應用程序對堆塊的不正確使用。通常情形包括釋放已釋放的堆塊或使用已釋放的堆塊,以及塊的越界重寫等明顯問題。(破壞不在本文討論范圍之內。有關內存重寫和泄漏等其他細節,請參見?Microsoft?Visual?C++(R)?調試文檔?。)


頻繁的分配和重分配造成的速度減慢。這是使用腳本語言時非常普遍的現象。如字符串被反復分配,隨重分配增長和釋放。不要這樣做,如果可能,盡量分配大字符串和使用緩沖區。另一種方法就是盡量少用連接操作。
競爭是在分配和釋放操作中導致速度減慢的問題。理想情況下,希望使用沒有競爭和快速分配/釋放的堆。可惜,現在還沒有這樣的通用堆,也許將來會有。

在所有的服務器系統中(如?IIS、MSProxy、DatabaseStacks、網絡服務器、?Exchange?和其他),?堆鎖定實在是個大瓶頸。處理器數越多,競爭就越會惡化。

盡量減少堆的使用
現在您明白使用堆時存在的問題了,難道您不想擁有能解決這些問題的超級魔棒嗎?我可希望有。但沒有魔法能使堆運行加快—因此不要期望在產品出貨之前的最后一星期能夠大為改觀。如果提前規劃堆策略,情況將會大大好轉。調整使用堆的方法,減少對堆的操作是提高性能的良方。

如何減少使用堆操作?通過利用數據結構內的位置可減少堆操作的次數。請考慮下列實例:

struct?ObjectA?{
???//?objectA?的數據?
}

struct?ObjectB?{
???//?objectB?的數據?
}

//?同時使用?objectA?和?objectB

//
//?使用指針?
//
struct?ObjectB?{
???struct?ObjectA?*?pObjA;
???//?objectB?的數據?
}

//
//?使用嵌入
//
struct?ObjectB?{
???struct?ObjectA?pObjA;
???//?objectB?的數據?
}

//
//?集合?–?在另一對象內使用?objectA?和?objectB
//

struct?ObjectX?{
???struct?ObjectA??objA;
???struct?ObjectB??objB;
}

避免使用指針關聯兩個數據結構。如果使用指針關聯兩個數據結構,前面實例中的對象?A?和?B?將被分別分配和釋放。這會增加額外開銷—我們要避免這種做法。


把帶指針的子對象嵌入父對象。當對象中有指針時,則意味著對象中有動態元素(百分之八十)和沒有引用的新位置。嵌入增加了位置從而減少了進一步分配/釋放的需求。這將提高應用程序的性能。


合并小對象形成大對象(聚合)。聚合減少分配和釋放的塊的數量。如果有幾個開發者,各自開發設計的不同部分,則最終會有許多小對象需要合并。集成的挑戰就是要找到正確的聚合邊界。


內聯緩沖區能夠滿足百分之八十的需要(aka?80-20?規則)。個別情況下,需要內存緩沖區來保存字符串/二進制數據,但事先不知道總字節數。估計并內聯一個大小能滿足百分之八十需要的緩沖區。對剩余的百分之二十,可以分配一個新的緩沖區和指向這個緩沖區的指針。這樣,就減少分配和釋放調用并增加數據的位置空間,從根本上提高代碼的性能。


在塊中分配對象(塊化)。塊化是以組的方式一次分配多個對象的方法。如果對列表的項連續跟蹤,例如對一個?{名稱,值}?對的列表,有兩種選擇:選擇一是為每一個“名稱-值”對分配一個節點;選擇二是分配一個能容納(如五個)“名稱-值”對的結構。例如,一般情況下,如果存儲四對,就可減少節點的數量,如果需要額外的空間數量,則使用附加的鏈表指針。?
塊化是友好的處理器高速緩存,特別是對于?L1-高速緩存,因為它提供了增加的位置?—不用說對于塊分配,很多數據塊會在同一個虛擬頁中。

正確使用?_amblksiz。C?運行時?(CRT)?有它的自定義前端分配程序,該分配程序從后端(Win32?堆)分配大小為?_amblksiz?的塊。將?_amblksiz?設置為較高的值能潛在地減少對后端的調用次數。這只對廣泛使用?CRT?的程序適用。
使用上述技術將獲得的好處會因對象類型、大小及工作量而有所不同。但總能在性能和可升縮性方面有所收獲。另一方面,代碼會有點特殊,但如果經過深思熟慮,代碼還是很容易管理的。

其他提高性能的技術
下面是一些提高速度的技術:?

使用?Windows?NT5?堆?
由于幾個同事的努力和辛勤工作,1998?年初?Microsoft?Windows(R)?2000?中有了幾個重大改進:

改進了堆代碼內的鎖定。堆代碼對每堆一個鎖。全局鎖保護堆數據結構,防止多線程式的使用。但不幸的是,在高通信量的情況下,堆仍受困于全局鎖,導致高競爭和低性能。Windows?2000?中,鎖內代碼的臨界區將競爭的可能性減到最小,從而提高了可伸縮性。


使用?“Lookaside”列表。堆數據結構對塊的所有空閑項使用了大小在?8?到?1,024?字節(以?8-字節遞增)的快速高速緩存。快速高速緩存最初保護在全局鎖內。現在,使用?lookaside?列表來訪問這些快速高速緩存空閑列表。這些列表不要求鎖定,而是使用?64?位的互鎖操作,因此提高了性能。


內部數據結構算法也得到改進。
這些改進避免了對分配高速緩存的需求,但不排除其他的優化。使用?Windows?NT5?堆評估您的代碼;它對小于?1,024?字節?(1?KB)?的塊(來自前端分配程序的塊)是最佳的。GlobalAlloc()?和?LocalAlloc()?建立在同一堆上,是存取每個進程堆的通用機制。如果希望獲得高的局部性能,則使用?Heap(R)?API?來存取每個進程堆,或為分配操作創建自己的堆。如果需要對大塊操作,也可以直接使用?VirtualAlloc()?/?VirtualFree()?操作。

上述改進已在?Windows?2000?beta?2?和?Windows?NT?4.0?SP4?中使用。改進后,堆鎖的競爭率顯著降低。這使所有?Win32?堆的直接用戶受益。CRT?堆建立于?Win32?堆的頂部,但它使用自己的小塊堆,因而不能從?Windows?NT?改進中受益。(Visual?C++?版本?6.0?也有改進的堆分配程序。)

使用分配高速緩存?
分配高速緩存允許高速緩存分配的塊,以便將來重用。這能夠減少對進程堆(或全局堆)的分配/釋放調用的次數,也允許最大限度的重用曾經分配的塊。另外,分配高速緩存允許收集統計信息,以便較好地理解對象在較高層次上的使用。

典型地,自定義堆分配程序在進程堆的頂部實現。自定義堆分配程序與系統堆的行為很相似。主要的差別是它在進程堆的頂部為分配的對象提供高速緩存。高速緩存設計成一套固定大小(如?32?字節、64?字節、128?字節等)。這一個很好的策略,但這種自定義堆分配程序丟失與分配和釋放的對象相關的“語義信息”。?

與自定義堆分配程序相反,“分配高速緩存”作為每類分配高速緩存來實現。除能夠提供自定義堆分配程序的所有好處之外,它們還能夠保留大量語義信息。每個分配高速緩存處理程序與一個目標二進制對象關聯。它能夠使用一套參數進行初始化,這些參數表示并發級別、對象大小和保持在空閑列表中的元素的數量等。分配高速緩存處理程序對象維持自己的私有空閑實體池(不超過指定的閥值)并使用私有保護鎖。合在一起,分配高速緩存和私有鎖減少了與主系統堆的通信量,因而提供了增加的并發、最大限度的重用和較高的可伸縮性。

需要使用清理程序來定期檢查所有分配高速緩存處理程序的活動情況并回收未用的資源。如果發現沒有活動,將釋放分配對象的池,從而提高性能。

可以審核每個分配/釋放活動。第一級信息包括對象、分配和釋放調用的總數。通過查看它們的統計信息可以得出各個對象之間的語義關系。利用以上介紹的許多技術之一,這種關系可以用來減少內存分配。

分配高速緩存也起到了調試助手的作用,幫助您跟蹤沒有完全清除的對象數量。通過查看動態堆棧返回蹤跡和除沒有清除的對象之外的簽名,甚至能夠找到確切的失敗的調用者。

MP?堆?
MP?堆是對多處理器友好的分布式分配的程序包,在?Win32?SDK(Windows?NT?4.0?和更新版本)中可以得到。最初由?JVert?實現,此處堆抽象建立在?Win32?堆程序包的頂部。MP?堆創建多個?Win32?堆,并試圖將分配調用分布到不同堆,以減少在所有單一鎖上的競爭。

本程序包是好的步驟?—一種改進的?MP-友好的自定義堆分配程序。但是,它不提供語義信息和缺乏統計功能。通常將?MP?堆作為?SDK?庫來使用。如果使用這個?SDK?創建可重用組件,您將大大受益。但是,如果在每個?DLL?中建立這個?SDK?庫,將增加工作設置。

重新思考算法和數據結構?
要在多處理器機器上伸縮,則算法、實現、數據結構和硬件必須動態伸縮。請看最經常分配和釋放的數據結構。試問,“我能用不同的數據結構完成此工作嗎?”例如,如果在應用程序初始化時加載了只讀項的列表,這個列表不必是線性鏈接的列表。如果是動態分配的數組就非常好。動態分配的數組將減少內存中的堆塊和碎片,從而增強性能。

減少需要的小對象的數量減少堆分配程序的負載。例如,我們在服務器的關鍵處理路徑上使用五個不同的對象,每個對象單獨分配和釋放。一起高速緩存這些對象,把堆調用從五個減少到一個,顯著減少了堆的負載,特別當每秒鐘處理?1,000?個以上的請求時。

如果大量使用“Automation”結構,請考慮從主線代碼中刪除“Automation?BSTR”,或至少避免重復的?BSTR?操作。(BSTR?連接導致過多的重分配和分配/釋放操作。)

摘要
對所有平臺往往都存在堆實現,因此有巨大的開銷。每個單獨代碼都有特定的要求,但設計能采用本文討論的基本理論來減少堆之間的相互作用。?

評價您的代碼中堆的使用。


改進您的代碼,以使用較少的堆調用:分析關鍵路徑和固定數據結構。


在實現自定義的包裝程序之前使用量化堆調用成本的方法。


如果對性能不滿意,請要求?OS?組改進堆。更多這類請求意味著對改進堆的更多關注。


要求?C?運行時組針對?OS?所提供的堆制作小巧的分配包裝程序。隨著?OS?堆的改進,C?運行時堆調用的成本將減小。


操作系統(Windows?NT?家族)正在不斷改進堆。請隨時關注和利用這些改進。
Murali?Krishnan?是?Internet?Information?Server?(IIS)?組的首席軟件設計工程師。從?1.0?版本開始他就設計?IIS,并成功發行了?1.0?版本到?4.0?版本。Murali?組織并領導?IIS?性能組三年?(1995-1998),?從一開始就影響?IIS?性能。他擁有威斯康星州?Madison?大學的?M.S.和印度?Anna?大學的?B.S.。工作之外,他喜歡閱讀、打排球和家庭烹飪。



http://community.csdn.net/Expert/FAQ/FAQ_Index.asp?id=172835
我在學習對象的生存方式的時候見到一種是在堆棧(stack)之中,如下??
CObject??object;??
還有一種是在堆(heap)中??如下??
CObject*??pobject=new??CObject();??
?
請問??
(1)這兩種方式有什么區別???
(2)堆棧與堆有什么區別????
?
?
---------------------------------------------------------------??
?
1)??about??stack,??system??will??allocate??memory??to??the??instance??of??object??automatically,??and??to??the??heap,??you??must??allocate??memory??to??the??instance??of??object??with??new??or??malloc??manually.??
2)??when??function??ends,??system??will??automatically??free??the??memory??area??of??stack,??but??to??the??heap,??you??must??free??the??memory??area??manually??with??free??or??delete,??else??it??will??result??in??memory??leak.??
3)棧內存分配運算內置于處理器的指令集中,效率很高,但是分配的內存容量有限。??
4)堆上分配的內存可以有我們自己決定,使用非常靈活。??
---------------------------------------------------------------??
?
?
堆和棧的比較??
?
?????從堆和棧的功能和作用來通俗的比較,堆主要用來存放對象的,棧主要是用來執行程序的.而這種不同又主要是由于堆和棧的特點決定的:??
?
?????在編程中,例如C/C++中,所有的方法調用都是通過棧來進行的,所有的局部變量,形式參數都是從棧中分配內存空間的。實際上也不是什么分配,只是從棧頂向上用就行,就好像工廠中的傳送帶(conveyor??belt)一樣,Stack??Pointer會自動指引你到放東西的位置,你所要做的只是把東西放下來就行.退出函數的時候,修改棧指針就可以把棧中的內容銷毀.這樣的模式速度最快,當然要用來運行程序了.需要注意的是,在分配的時候,比如為一個即將要調用的程序模塊分配數據區時,應事先知道這個數據區的大小,也就說是雖然分配是在程序運行時進行的,但是分配的大小多少是確定的,不變的,而這個"大小多少"是在編譯時確定的,不是在運行時.??
?
?????堆是應用程序在運行的時候請求操作系統分配給自己內存,由于從操作系統管理的內存分配,所以在分配和銷毀時都要占用時間,因此用堆的效率非常低.但是堆的優點在于,編譯器不必知道要從堆里分配多少存儲空間,也不必知道存儲的數據要在堆里停留多長的時間,因此,用堆保存數據時會得到更大的靈活性。事實上,面向對象的多態性,堆內存分配是必不可少的,因為多態變量所需的存儲空間只有在運行時創建了對象之后才能確定.在C++中,要求創建一個對象時,只需用new命令編制相關的代碼即可。執行這些代碼時,會在堆里自動進行數據的保存.當然,為達到這種靈活性,必然會付出一定的代價:在堆里分配存儲空間時會花掉更長的時間!這也正是導致效率低的原因,??
?
我想你現在該明白了吧。:)

總結

以上是生活随笔為你收集整理的用VC写Assembly代码(6)--附录2[windows进程中的内存结构]的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

中文字幕999 | 婷婷精品国产欧美精品亚洲人人爽 | 中文字幕欧美日韩va免费视频 | 成人免费在线播放 | 2021国产视频 | 在线播放 日韩专区 | 精品96久久久久久中文字幕无 | 久久97超碰 | 96av视频 | 国产资源网 | 91夫妻视频| 中文字幕在线观看网 | 免费成人在线电影 | 久久综合色婷婷 | 九九九九九九精品 | 成人综合婷婷国产精品久久免费 | 亚洲欧美日本一区二区三区 | 韩国av免费在线 | 久久综合五月婷婷 | 少妇搡bbb| 黄色网址国产 | 国产精品 日韩精品 | 人人爱爱 | 中文永久字幕 | 美州a亚洲一视本频v色道 | 久久黄色片子 | 99热99热 | 天天色天天操天天爽 | 国产精品久久久亚洲 | 亚洲美女视频在线 | 久热久草在线 | 欧美日韩国产xxx | 国产xx视频 | 婷婷激情综合五月天 | av一级在线 | 区一区二在线 | 97碰视频| 久久美女视频 | 69视频在线播放 | 亚洲影院一区 | 国内精品久久久久 | 久久精品www人人爽人人 | 99精品国产免费久久久久久下载 | 最新国产精品拍自在线播放 | 亚洲电影院 | 九九久久精品 | 日本黄色大片免费看 | 午夜色影院 | 欧美91精品久久久久国产性生爱 | 激情婷婷av | 欧美aa一级 | 一区三区在线欧 | 性色av免费在线观看 | 在线观看www视频 | 在线性视频日韩欧美 | 精品欧美一区二区在线观看 | 亚洲一区二区天堂 | 日本精品二区 | 美女视频网 | 国产一区视频在线观看免费 | 一区二区视频网站 | 色999视频| 国产 日韩 中文字幕 | 91网站在线视频 | 天天碰天天操 | 成人在线观看你懂的 | 一区二区观看 | 亚洲成av人片在线观看无 | 嫩草av在线 | 亚洲精品乱码白浆高清久久久久久 | 免费成人av| 日本中文字幕在线一区 | jizz18欧美18 | 国产a免费| 亚洲九九精品 | 欧美极品少妇xxxx | 亚洲欧美日韩国产一区二区三区 | 欧美韩日在线 | 91中文在线 | 天天看天天干 | 色丁香综合 | 色香蕉在线视频 | 最新国产精品久久精品 | 亚洲aⅴ在线观看 | 99久久精品午夜一区二区小说 | 一区在线观看 | 日操干| 日日弄天天弄美女bbbb | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | www久| 午夜视频不卡 | 日韩va欧美va亚洲va久久 | 日韩一二区在线观看 | 日本三级香港三级人妇99 | 美女激情影院 | 久久福利精品 | 久久精品99久久久久久2456 | 一二三区高清 | 亚洲一级免费电影 | 国产成人av电影在线观看 | 在线观看成人一级片 | 亚洲日本在线一区 | 国产成人精品不卡 | 国产精品系列在线播放 | 久草免费在线视频 | 一本—道久久a久久精品蜜桃 | 国外调教视频网站 | 欧美精品乱码久久久久 | 亚洲精品乱码久久久久久写真 | 日日插日日干 | 亚洲激精日韩激精欧美精品 | 免费av在| www日韩欧美 | 国产精品高清在线观看 | 黄色国产高清 | 欧美一级高清片 | 超碰在线最新网址 | 激情综合五月婷婷 | 国产va精品免费观看 | 久久国产精品色av免费看 | 亚洲综合激情五月 | 久久精品老司机 | 五月婷婷激情五月 | 国产特级毛片aaaaaa | 国产精品久久一 | 91精品在线视频观看 | av免费成人 | 国产精品国产毛片 | 国产三级视频在线 | 国产你懂的在线 | 国产精品手机视频 | 国产黄色在线看 | 欧美一区三区四区 | 天天操天天添 | 欧美孕交vivoestv另类 | 日本在线观看视频一区 | 国产69精品久久久久99尤 | 午夜精品久久久久久久久久 | 精品日韩中文字幕 | 免费一级黄色 | 国产高清视频网 | 国产亚洲视频在线免费观看 | 日日精品 | 91丨九色丨丝袜 | 日韩在线色视频 | 成人免费一区二区三区在线观看 | 国产精品视频专区 | 日韩精品一区二区三区第95 | 一区二区三区影院 | 成年人免费在线观看网站 | 国产精品久久久久三级 | 996久久国产精品线观看 | 久久久久久久久久福利 | 久久久精品日本 | 欧美日韩1区 | 亚洲国产精品一区二区久久,亚洲午夜 | 精品极品在线 | 91正在播放 | 久草网免费 | 青青草华人在线视频 | 操久在线 | 国产白浆在线观看 | 成人午夜黄色影院 | 精品乱码一区二区三四区 | av免费在线看网站 | av久久在线 | 国产精品久久久久久一二三四五 | 九九国产视频 | 精品一区二区6 | 亚洲美女精品 | 国产精品一区在线 | 一区二区三区在线免费播放 | 国产一级视频 | 久久久999精品视频 国产美女免费观看 | 国产精品高清一区二区三区 | 在线观看日韩一区 | 欧美日韩伦理在线 | 在线观看一区视频 | 超碰97国产| 亚洲国产剧情av | 69视频国产| 九九视频在线播放 | www日韩在线观看 | 亚洲国产精品电影 | 久久久精品综合 | 亚洲九九爱 | 成人久久综合 | 西西www4444大胆在线 | 黄色com| av中文在线 | 在线观看激情av | 免费精品国产 | 中文 一区二区 | 亚洲视频 在线观看 | 成年人在线观看视频免费 | 99精品国产一区二区 | 肉色欧美久久久久久久免费看 | 激情图片区 | 婷婷丁香久久五月婷婷 | 97超碰中文字幕 | 欧美日韩性生活 | 成人国产精品入口 | 国产色在线视频 | 日韩理论片在线观看 | 天海冀一区二区三区 | 西西444www | 欧美日韩在线免费观看视频 | 欧美精品乱码久久久久久 | 免费国产在线精品 | 久久免费观看视频 | 免费电影一区二区三区 | 成年人毛片在线观看 | av品善网 | 日本精品一区二区三区在线播放视频 | 国产精品第 | 国产精品资源网 | 成人在线小视频 | 国产精品国产三级国产aⅴ无密码 | 国产在线999 | 91插插插网站 | 久久99精品久久久久久 | 午夜 在线| 精品福利视频在线 | 久久久久久久久久久精 | 99热精品在线观看 | 久久天堂网站 | 久久久免费视频播放 | 97爱| 免费观看成年人视频 | 亚洲狠狠婷婷综合久久久 | 欧美性色黄 | 亚洲一级黄色大片 | 免费av片在线 | 97超在线 | 激情五月婷婷网 | www.91国产| 亚洲成人av片 | 亚洲国产精品成人va在线观看 | 91麻豆免费视频 | 91精选在线观看 | av大片网址| 69久久夜色精品国产69 | 国产日韩在线观看一区 | 日韩网站在线免费观看 | 日韩影视精品 | 香蕉视频在线免费 | 色av网站| 亚洲天堂网在线观看视频 | 免费亚洲婷婷 | 免费黄色a网站 | www.天天操.com | 午夜黄色 | 国产精品久久三 | 色婷婷在线观看视频 | 天天色天天射天天操 | 免费久久网站 | 91丨九色丨91啦蝌蚪老版 | 中文字幕在线视频第一页 | 又黄又刺激视频 | 黄色精品一区二区 | 成人免费xxxxxx视频 | 日韩精品一区二区三区不卡 | 亚洲一二区精品 | 97成人免费视频 | 99精品视频99 | 九九热在线免费观看 | 国产精品毛片网 | 正在播放国产91 | 又色又爽又黄高潮的免费视频 | 97视频人人澡人人爽 | 日日操网 | 亚洲欧美激情精品一区二区 | 在线成人小视频 | 狠狠色综合网站久久久久久久 | 亚洲精品网站在线 | 婷婷在线免费 | 久久久久亚洲最大xxxx | 久久精品免费观看 | 首页国产精品 | 国产精品系列在线 | 婷婷丁香激情 | 97成人精品视频在线观看 | 亚洲最快最全在线视频 | 97在线观看视频 | 视频一区二区三区视频 | av在线观 | 91综合久久一区二区 | 日韩久久久久久久久久 | 五月天精品视频 | 久久久久久久久久久久久久av | 中文字幕二区在线观看 | a黄色一级 | 在线观看中文字幕第一页 | av看片在线 | .精品久久久麻豆国产精品 亚洲va欧美 | 天天看天天干 | 国产在线综合视频 | 国产高清在线观看 | 日日爱视频 | 欧美一区二区在线刺激视频 | 色的网站在线观看 | 久久精品99北条麻妃 | 黄色app网站在线观看 | 国产精品久久久久久久久久久不卡 | 免费看黄的视频 | 一区二区三区四区五区在线 | 96久久欧美麻豆网站 | 国产中文字幕亚洲 | 国产午夜精品久久久久久久久久 | 国产99久久九九精品免费 | 91手机视频 | 久久精品国产免费看久久精品 | 九七视频在线观看 | 欧美a在线看 | www.福利| 香蕉视频91 | 日日干天天干 | 一区二区三区四区在线 | 热久久国产 | 啪啪凸凸| 四虎免费在线观看 | 九九九热 | 三级黄在线 | 成人黄色大片在线观看 | 在线电影av | 四虎小视频 | 中文字幕欧美日韩va免费视频 | 中文字幕在线网 | 2021久久| 一级免费黄色 | 国产精品久久久久三级 | 天天操天天干天天爱 | 国产特级毛片aaaaaaa高清 | 4438全国亚洲精品观看视频 | 永久免费精品视频 | 伊人亚洲综合 | 91精品中文字幕 | 国产精品手机看片 | 波多野结衣电影一区二区 | 婷婷激情影院 | 在线观看午夜 | 五月天狠狠操 | 日韩精品观看 | 国产精品亚洲人在线观看 | 欧美日本在线视频 | 色综合天天综合 | 欧美一级日韩免费不卡 | 免费网址在线播放 | 超碰人人在线观看 | 国产中文字幕视频在线 | 高清久久久久久 | 日韩精品中文字幕有码 | 91丨九色丨91啦蝌蚪老版 | 91精品蜜桃| 波多野结衣精品视频 | 福利av影院 | h动漫中文字幕 | 亚洲天堂自拍视频 | 国产在线观看91 | 国产在线视频一区二区 | 天天操天天射天天插 | 久久精品视频在线免费观看 | 久久免费看视频 | 好看的国产精品视频 | 久久综合久久综合久久综合 | 日韩在线观看电影 | 国产高清一区二区 | 中文字幕在线影院 | 久久久国产精品人人片99精片欧美一 | 久草亚洲视频 | 天天干天天草天天爽 | 成人黄色影片在线 | 97在线成人 | 黄色一级影院 | 国产精品日韩欧美 | 国产成人一区二区三区在线观看 | 国产99在线| 国产日韩欧美在线播放 | 五月婷婷中文网 | 免费看色的网站 | 月丁香婷婷 | 中文字幕刺激在线 | 99精品国产一区二区 | 日韩 在线a | 国产视频久久久 | 久久久久久久久久久久影院 | 天天综合导航 | 久久成人18免费网站 | 久久草草热国产精品直播 | 天天摸天天操天天爽 | 又爽又黄又无遮挡网站动态图 | 欧美国产一区在线 | 在线91av| 久久男人中文字幕资源站 | 啪啪免费试看 | 免费日韩 精品中文字幕视频在线 | av免费网站在线观看 | 国产一级片免费播放 | h视频在线看 | 久久久在线| 成年人网站免费在线观看 | 高清不卡毛片 | 一区二区三区四区在线免费观看 | 精品国产一区二区三区男人吃奶 | 久久久久久久18 | 看片一区二区三区 | 免费一级片视频 | 国产最新福利 | 91免费高清视频 | 九九日九九操 | 免费看黄的 | 国内三级在线 | 亚洲乱码一区 | 亚洲伦理精品 | 狠狠艹夜夜干 | 91最新视频在线观看 | 国产一区二区高清视频 | 精品亚洲va在线va天堂资源站 | 日韩系列 | 国产一区二区三区黄 | 午夜精品久久久久久久99 | 国内精品久久久久影院一蜜桃 | 亚洲日本色 | 久香蕉| 在线亚洲欧美视频 | 一区二区三区污 | 国产精品影音先锋 | 欧洲精品二区 | 首页av在线 | 婷婷在线不卡 | 天天操天天操天天操天天操 | 日本丶国产丶欧美色综合 | 丁香亚洲 | 在线观看日韩中文字幕 | 精品视频久久 | 欧美日韩一区三区 | 亚洲乱码国产乱码精品天美传媒 | 色91在线视频 | 日韩激情网 | 二区三区中文字幕 | 夜色成人av| 三级av网站 | 欧美日韩99 | 国产黄免费在线观看 | 色哟哟国产精品 | 精品一区二区在线观看 | 88av色 | 国产精品免费视频观看 | 黄色1级大片| 欧美国产不卡 | 人人射网站| 国产在线精品一区二区三区 | 黄色在线观看www | 欧美片一区二区三区 | 国产精品久久久777 成人手机在线视频 | 日韩欧美综合在线视频 | 香蕉免费| 丁香婷婷成人 | 免费无遮挡动漫网站 | 天堂av在线 | 一区二区三区免费网站 | 911香蕉视频| 麻豆免费视频网站 | 毛片网在线| 久久爽久久爽久久av东京爽 | 亚洲我射av | 午夜视频导航 | 91插插影库 | 国产不卡精品视频 | 天天天干天天天操 | 国产精品永久免费 | 天堂av在线网 | 麻豆视频大全 | 97在线观| 久久看毛片 | 伊人久久国产精品 | 综合色站 | 国产手机视频在线 | 91网免费观看 | 黄av资源 | 黄色软件在线观看免费 | 日韩久久精品 | 亚洲欧洲在线视频 | 亚洲美女视频网 | 久久久综合色 | 激情校园亚洲 | 久久黄视频 | 91精品一 | 天天草天天干天天射 | 天天色天天艹 | 天天躁天天躁天天躁婷 | 久色网| 日韩成人看片 | 日韩理论影院 | 午夜国产成人 | 免费成人短视频 | 免费高清男女打扑克视频 | 亚洲经典视频在线观看 | 日韩av在线资源 | 亚洲成熟女人毛片在线 | 福利视频网址 | 中文字幕在线字幕中文 | 久久视频99 | 中文字幕一区二区在线观看 | 激情视频免费在线观看 | 91喷水 | 国产日产精品一区二区三区四区的观看方式 | av解说在线| 免费看的黄色录像 | 亚洲黄色一级大片 | 丁香六月综合网 | 欧美日韩在线观看一区二区三区 | 天天干天天色2020 | 婷婷综合伊人 | 欧美一级专区免费大片 | 国内精品免费久久影院 | 久久久资源 | 国内综合精品午夜久久资源 | 激情www| 久久在线免费 | 东方av在线免费观看 | 久久视频网址 | 天天操夜夜逼 | 欧美91在线 | 伊人天天综合 | 免费在线观看91 | 在线免费观看欧美日韩 | www.久久视频 | 欧美一级久久 | 色综合咪咪久久网 | 黄色网址中文字幕 | 国产成人久久精品77777综合 | 欧美不卡视频在线 | 亚洲天堂va | 国内一级片在线观看 | 日操操 | 亚洲一级片在线观看 | 成人欧美一区二区三区在线观看 | 日产乱码一二三区别免费 | 成人资源网 | 国产精品综合久久久久 | 国产精品18久久久久久久网站 | 天天摸天天舔天天操 | 日韩国产欧美在线播放 | 亚洲高清视频在线观看免费 | 色婷婷天天干 | 免费黄色在线 | 国产在线 一区二区三区 | 99人久久精品视频最新地址 | 日韩丝袜| 国产在线国偷精品产拍 | av中文字幕日韩 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 狠狠躁日日躁狂躁夜夜躁 | 在线91观看 | 亚洲精品国精品久久99热一 | 日韩在线一级 | 激情婷婷亚洲 | 美女网站免费福利视频 | 亚洲精品乱码久久久久久蜜桃欧美 | 婷婷五天天在线视频 | 欧美aa在线观看 | 国内一区二区视频 | 国产精品va在线播放 | 久久激五月天综合精品 | 亚一亚二国产专区 | 久久免费视频7 | 激情在线五月天 | 久草电影免费在线观看 | 精品在线观看一区二区三区 | 又长又大又黑又粗欧美 | 日韩在线观看三区 | 美女在线国产 | 黄色一级网 | 国产日本高清 | 最新日韩在线 | 精品成人网 | 中国一级片视频 | 精品国偷自产国产一区 | 日韩午夜一级片 | 最近中文字幕mv | 国产99久久九九精品 | 一区精品在线 | 国产精品久久久久久久妇 | 五月天天色 | 96久久 | 久久综合视频网 | 欧美精品你懂的 | 91伊人久久大香线蕉蜜芽人口 | 免费视频99 | 五月婷婷综合激情网 | 欧美aaa大片| 日韩电影在线一区二区 | 国产看片 色 | 欧美另类视频 | 韩国av三级 | 激情视频91 | 亚洲国产欧洲综合997久久, | 九九九九热精品免费视频点播观看 | 大胆欧美gogo免费视频一二区 | 玖玖精品在线 | 亚洲不卡av一区二区三区 | 在线观看www视频 | 激情综合色综合久久 | 久久精品国产亚洲aⅴ | 亚洲国产免费网站 | 久艹视频在线免费观看 | 人人草人人做 | 精品一区在线 | 高清视频一区二区三区 | 综合色播 | 日韩精品一二三 | 亚洲国产精品第一区二区 | 国产美女在线免费观看 | 国产aaa毛片| 激情网五月天 | 91香蕉亚洲精品 | 久久久久亚洲精品男人的天堂 | av再线观看 | 97精品国产91久久久久久久 | 一区二区三区四区影院 | 久久精品欧美日韩精品 | 99精品在线观看视频 | 久久久久久久网 | 成人一区二区三区在线 | 97夜夜澡人人爽人人免费 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 国产成人一区二区精品非洲 | 国产一二区视频 | 在线小视频你懂得 | 97超碰网 | 天天干天天操天天干 | 欧美激情精品久久久久久变态 | 久久午夜免费视频 | 特级大胆西西4444www | 丁香花中文字幕 | 久久精品中文字幕一区二区三区 | 国产一区二区久久 | av亚洲产国偷v产偷v自拍小说 | 中文字幕亚洲综合久久五月天色无吗'' | 日韩在线观看一区 | 五月婷婷中文 | 天堂av网站 | 99久久精品久久久久久清纯 | 91大神在线观看视频 | 在线成人观看 | 一区二区三区动漫 | 人交video另类hd | 日韩电影在线观看一区二区三区 | 欧美一级视频在线观看 | 色综合天天视频在线观看 | 天天激情在线 | 97超碰人人爱 | 欧美在线日韩在线 | 精品一区av | 久久国产精彩视频 | 69精品久久久 | 玖玖玖国产精品 | 免费高清在线视频一区· | 在线av资源 | 婷婷国产在线 | 色五月激情五月 | 国产精品精品久久久久久 | 黄色一级免费 | 欧美一区二区三区免费观看 | 成人av资源| 麻豆一精品传二传媒短视频 | 亚洲日韩中文字幕 | 日韩一区二区三区在线观看 | 久久激情网站 | 色黄www小说 | 色在线视频 | 国产精品中文字幕在线播放 | av资源免费看 | 国产精品久久久久久久久软件 | 久久亚洲欧美日韩精品专区 | 日韩一区在线播放 | 九色激情网 | 国产黄影院色大全免费 | 97超碰资源网 | 国产精品日韩欧美一区二区 | 91精品综合| 韩日av在线 | 99久久久成人国产精品 | 亚洲一区二区高潮无套美女 | 久久婷婷一区二区三区 | 天天拍天天草 | 日韩高清一区 | 91精品亚洲影视在线观看 | www最近高清中文国语在线观看 | 国产在线视频一区二区三区 | av大片免费在线观看 | 91亚洲国产成人 | 91私密视频 | a色网站 | 日韩免费观看一区二区三区 | 欧美视频日韩视频 | 视频三区在线 | 中文字幕在线播放日韩 | 亚洲国产精品va在线 | 久久久久久久久毛片 | 99精品色 | 免费在线观看不卡av | 又黄又爽的视频在线观看网站 | 永久av免费在线观看 | 激情网站网址 | 久久久综合精品 | 欧美日韩视频一区二区三区 | 亚洲精品午夜久久久久久久久久久 | 在线国产精品视频 | 亚洲91精品| 国产精品毛片一区二区在线 | 亚洲精品视频免费在线观看 | 欧美a在线免费观看 | 视频二区在线 | 免费a级毛片在线看 | 国产视频精选在线 | 九九导航 | 久久国产精品偷 | 99爱爱| av中文在线观看 | 日韩精品aaa | 尤物97国产精品久久精品国产 | 国产精品18久久久久久久网站 | 国产在线国偷精品产拍免费yy | 正在播放久久 | 久久r精品| 欧美久久久久久久久久久 | 女人18片 | 国产成人精品免高潮在线观看 | avwww在线观看 | 亚洲午夜激情网 | 日日天天干 | 日韩在线资源 | 97在线观看免费视频 | 99精品视频免费观看视频 | 五月天激情综合 | 国产亚洲精品女人久久久久久 | 天天综合网天天综合色 | 国产精品热视频 | 精品久久一 | 欧美日韩大片在线观看 | 亚洲精品在线视频观看 | 伊人久久在线观看 | 国产成人精品av在线观 | 热久久视久久精品18亚洲精品 | 欧美一级视频免费 | 特级西西人体444是什么意思 | 国产女做a爱免费视频 | 国产精品福利在线播放 | 黄色av电影一级片 | 婷婷av网站 | 日韩黄色在线观看 | 国产午夜精品久久久久久久久久 | 国产在线观看,日本 | 国产不卡av在线 | 中文字幕亚洲欧美 | 91久久人澡人人添人人爽欧美 | 男女男视频 | 9999精品免费视频 | 精品国产成人av | 日本中文字幕一二区观 | 99在线热播精品免费 | 亚洲高清国产视频 | av中文资源在线 | 日韩一区二区免费在线观看 | 久久国色夜色精品国产 | 国内综合精品午夜久久资源 | 99热.com | 午夜精品视频福利 | 久久天天拍| 国产一区二区三区高清播放 | 在线网址你懂得 | 97久久精品午夜一区二区 | 日韩av一区二区在线 | 91在线www | 成人在线观看av | 丁香五月亚洲综合在线 | 国产资源在线播放 | 亚洲精品国产自产拍在线观看 | 丁香婷婷久久久综合精品国产 | 亚洲91av| 久久精品一区二区三区视频 | 色噜噜狠狠狠狠色综合 | 亚洲综合网 | 日韩精品一卡 | av在线免费不卡 | 97在线视频免费观看 | 欧美精品久久久久久久久久 | 色婷婷97| 永久免费毛片 | 九月婷婷人人澡人人添人人爽 | 91视频中文字幕 | 日本在线视频网址 | 丰满少妇高潮在线观看 | 国产91影院| 激情久久伊人 | 亚洲精品在线观看中文字幕 | 亚洲成aⅴ人在线观看 | 美女久久久久久久久久久 | 久久国产日韩 | av黄色国产 | 日日爽夜夜操 | 久久有精品 | 亚洲一区二区视频 | 国产原创在线 | 人人看97 | 欧美a级在线 | 在线www色 | 成人小视频免费在线观看 | 欧美日本中文字幕 | 国产又粗又猛又爽又黄的视频免费 | 国产一区二区在线视频观看 | 奇米网8888 | 国产1区在线观看 | 日韩免费b | av在线电影网站 | 久久网页 | 91成人久久 | 日韩激情三级 | 国产网站在线免费观看 | 精品一区二区av | 国产99久久精品一区二区永久免费 | 免费黄在线观看 | 久久国色夜色精品国产 | 公开超碰在线 | 嫩草伊人久久精品少妇av | 欧美成人在线免费观看 | 国产高清日韩 | 国产精品美女www爽爽爽视频 | 日韩黄色大片在线观看 | a视频免费| 日产中文字幕 | 综合久久网站 | 久久久久免费看 | 国产精久久久久久妇女av | 久久精品系列 | 91网免费观看 | 久碰视频在线观看 | 欧美日韩性视频 | 精品久久一区二区三区 | 91一区啪爱嗯打偷拍欧美 | www.国产在线观看 | 国产美腿白丝袜足在线av | 亚洲无吗av | 欧美高清视频不卡网 | 国产精品久久久久永久免费 | 久久这里只有精品视频99 | 夜夜骑首页 | 三级大片网站 | 成人av一区二区在线观看 | 国产成人av电影 | 97在线视频观看 | 日韩午夜精品 | 精品自拍sae8—视频 | 久久99精品久久久久久久久久久久 | 91大神免费在线观看 | 五月天六月色 | 狠狠干狠狠艹 | 最新国产一区二区三区 | 国产精品国产三级国产不产一地 | 国产亚洲精品久久久久久久久久久久 | www178ccom视频在线 | 超碰国产在线播放 | 国产伦精品一区二区三区无广告 | 日韩女同一区二区三区在线观看 | 91精品啪 | 91视频免费国产 | 免费观看久久 | 中文字幕免费高清 | 国产精品久久久久久一区二区 | 91免费观看视频网站 | 国产精品久久精品 | 亚洲一级在线观看 | 免费日韩 精品中文字幕视频在线 | 国产一级a毛片视频爆浆 | 国产1级毛片 | 欧美日一级片 | 香蕉视频网站在线观看 | 99久久婷婷国产综合亚洲 | 在线看岛国av | 欧美成人h版在线观看 | 国产群p视频 | 国产精品久久久久久久免费 | 欧美性久久久 | 久久国产经典视频 | 综合久久影院 | 欧美精品午夜 | 国产精品不卡av | 国产99久久久国产精品免费二区 | 国产精品永久免费观看 | 色婷婷亚洲婷婷 | 成人国产在线 | 999成人免费视频 | 精品一区二区三区电影 | 亚洲精品成人av在线 | 精品国产一区二区三区久久 | 少妇高潮冒白浆 | 久久婷婷色综合 | 高清精品在线 | 亚洲精品影视 | 高清av网 | 夜添久久精品亚洲国产精品 | 久久黄色片子 | 日韩av电影国产 | 9在线观看免费高清完整版在线观看明 | 久久久福利视频 | 黄色一级大片在线免费看产 | 日日干日日 | 欧美久久电影 | 91精品一区国产高清在线gif | 在线黄色免费 | 韩国精品一区二区三区六区色诱 | .国产精品成人自产拍在线观看6 | 国产在线p | 成人天堂网 | 久久综合免费视频 | 四虎影视成人精品 | 一区在线观看 | 奇米影视777影音先锋 | 午夜电影中文字幕 | 狠狠色伊人亚洲综合网站色 | 国产一区二区不卡视频 | 欧美另类美少妇69xxxx | 中文在线a天堂 | 欧美经典久久 | 免费看的国产视频网站 | 看国产黄色大片 | 三日本三级少妇三级99 | 国产一区二区在线免费播放 | 日韩精品视频免费看 | 日韩欧美综合精品 | 久久精品麻豆 | 精品久久久久久亚洲综合网站 | 免费在线观看的av网站 | 日韩高清免费观看 | 午夜精品久久久久久久99 | 97超视频免费观看 | 狠狠夜夜 | 日韩欧美一区二区三区免费观看 | 久久久毛片 | 综合久久久久久久 | 精品久久国产一区 | 国产精品久久久久久a | 久久爽久久爽久久av东京爽 | 精品一区三区 | 在线看成人 | 国产成人精品在线播放 | 免费三级网| 九九视频精品在线 | 天天做天天爱天天爽综合网 | 午夜国产影院 | 国产亚洲精品久久久久动 | 亚洲综合精品视频 | 婷婷激情影院 | 国产精品久久久久999 | 久久一区二区三区日韩 | 久久久国产影院 | 六月丁香在线观看 | 午夜成人免费电影 | 天堂在线一区 | 欧美日韩三级在线观看 | 久久久国产精品电影 | 天天插天天狠天天透 | 亚洲成人精品av | 极品久久久久 | 中文字幕在线观看不卡 | 国产福利网站 | 亚洲高清av在线 | 亚洲黄色区 | 天天色欧美 | 久久在现| 丁香婷婷社区 | 午夜视频不卡 | 国产亚洲精品美女 | 亚洲高清在线 | 91在线国产观看 | 91精品啪在线观看国产线免费 | 韩日在线一区 | 黄色成人毛片 | 欧美a在线免费观看 | 高潮久久久久久久久 | 国产人成在线视频 | 中文永久免费观看 | 毛片网在线播放 | 国产精品久久久久国产精品日日 | 九九精品毛片 | 国产综合视频在线观看 | 国产99久久九九精品免费 | 黄色片网站av | 成人亚洲精品久久久久 | 亚洲无人区小视频 | 黄色中文字幕 | 亚洲成av人片在线观看无 | 久久综合网色—综合色88 | 国产色网 | 久久免费观看少妇a级毛片 久久久久成人免费 | www.久久视频 |