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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > windows >内容正文

windows

Windows Socket五种I/O模型

發(fā)布時(shí)間:2025/3/17 windows 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Windows Socket五种I/O模型 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

? ? ?如果你想在Windows平臺(tái)上構(gòu)建服務(wù)器應(yīng)用,那么I/O模型是你必須考慮的。Windows操作系統(tǒng)提供了Select、WSAAsyncSelect、WSAEventSelect、Overlapped I/O和Completion Port共五種I/O模型。每一種模型均適用于一種特定的應(yīng)用場(chǎng)景。寫代碼時(shí)應(yīng)該對(duì)自己的應(yīng)用需求非常明確,而且綜合考慮到程序的擴(kuò)展性和可移植性等因素,作出自己的選擇。

? ? ? ? 客戶端的代碼(為代碼直觀,省去所有錯(cuò)誤檢查,以下同):

#include?<WINSOCK2.H> #include?<stdio.h> #define?SERVER_ADDRESS?"137.117.2.148" #define?PORT???????????5150 #define?MSGSIZE????????1024 #pragma?comment(lib,?"ws2_32.lib") int?main() {WSADATA?????wsaData;SOCKET??????sClient;SOCKADDR_IN?server;char????????szMessage[MSGSIZE];int?????????ret;?WSAStartup(0x0202,?&wsaData);?sClient?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);?memset(&server,?0,?sizeof(SOCKADDR_IN));server.sin_family?=?AF_INET;server.sin_addr.S_un.S_addr?=?inet_addr(SERVER_ADDRESS);server.sin_port?=?htons(PORT);connect(sClient,?(struct?sockaddr?*)&server,?sizeof(SOCKADDR_IN));while?(TRUE){printf("Send:");gets(szMessage);?send(sClient,?szMessage,?strlen(szMessage),?0);//?Receive?messageret?=?recv(sClient,?szMessage,?MSGSIZE,?0);szMessage[ret]?=?'\0';printf("Received?[%d?bytes]:?'%s'\n",?ret,?szMessage);}//?Clean?upclosesocket(sClient);WSACleanup();return?0; }

????客戶端所做的事情相當(dāng)簡(jiǎn)單,創(chuàng)建套接字,連接服務(wù)器,然后不停的發(fā)送和接收數(shù)據(jù)。

? ??比較容易想到的一種服務(wù)器模型就是采用一個(gè)主線程,負(fù)責(zé)監(jiān)聽客戶端的連接請(qǐng)求,當(dāng)接收到某個(gè)客戶端的連接請(qǐng)求后,創(chuàng)建一個(gè)專門用于和該客戶端通信的套接字和一個(gè)輔助線程。以后該客戶端和服務(wù)器的交互都在這個(gè)輔助線程內(nèi)完成。這種方法比較直觀,程序非常簡(jiǎn)單而且可移植性好,但是不能利用平臺(tái)相關(guān)的特性。例如,如果連接數(shù)增多的時(shí)候(成千上萬(wàn)的連接),那么線程數(shù)成倍增長(zhǎng),操作系統(tǒng)忙于頻繁的線程間切換,而且大部分線程在其生命周期內(nèi)都是處于非活動(dòng)狀態(tài)的,這大大浪費(fèi)了系統(tǒng)的資源。

一.選擇模型
??? ????Select模型是Winsock中最常見的I/O模型。之所以稱其為“Select模型”,是由于它的“中心思想”便是利用select函數(shù),實(shí)現(xiàn)對(duì)I/O的管理。最初設(shè)計(jì)該模型時(shí),主要面向的是某些使用UNIX操作系統(tǒng)的計(jì)算機(jī),它們采用的是Berkeley套接字方案。Select模型已集成到Winsock 1.1中,它使那些想避免在套接字調(diào)用過程中被無(wú)辜“鎖定”的應(yīng)用程序,采取一種有序的方式,同時(shí)進(jìn)行對(duì)多個(gè)套接字的管理。
服務(wù)器的代碼(已經(jīng)不能再精簡(jiǎn)了):

#include?<winsock.h> #include?<stdio.h> #define?PORT???????5150 #define?MSGSIZE????1024 #pragma?comment(lib,?"ws2_32.lib") int????g_iTotalConn?=?0; SOCKET?g_CliSocketArr[FD_SETSIZE]; DWORD?WINAPI?WorkerThread(LPVOID?lpParameter); int?main() {WSADATA?????wsaData;SOCKET??????sListen,?sClient;SOCKADDR_IN?local,?client;int?????????iaddrSize?=?sizeof(SOCKADDR_IN);DWORD???????dwThreadId;WSAStartup(0x0202,?&wsaData);sListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);local.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(SOCKADDR_IN));listen(sListen,?3);CreateThread(NULL,?0,?WorkerThread,?NULL,?0,?&dwThreadId);??while?(TRUE){sClient?=?accept(sListen,?(struct?sockaddr?*)&client,?&iaddrSize);printf("Accepted?client:%s:%d\n",?inet_ntoa(client.sin_addr),?ntohs(client.sin_port));g_CliSocketArr[g_iTotalConn++]?=?sClient;}return?0; } DWORD?WINAPI?WorkerThread(LPVOID?lpParam) {int????????????i;fd_set?????????fdread;int????????????ret;struct?timeval?tv?=?{1,?0};char???????????szMessage[MSGSIZE];while?(TRUE){FD_ZERO(&fdread);for?(i?=?0;?i?<?g_iTotalConn;?i++){FD_SET(g_CliSocketArr[i],?&fdread);}ret?=?select(0,?&fdread,?NULL,?NULL,?&tv);if?(ret?==?0){continue;}for?(i?=?0;?i?<?g_iTotalConn;?i++){if?(FD_ISSET(g_CliSocketArr[i],?&fdread)){ret?=?recv(g_CliSocketArr[i],?szMessage,?MSGSIZE,?0);if?(ret?==?0?||?(ret?==?SOCKET_ERROR?&&?WSAGetLastError()?==?WSAECONNRESET)){printf("Client?socket?%d?closed.\n",?g_CliSocketArr[i]);closesocket(g_CliSocketArr[i]);if?(i?<?g_iTotalConn?-?1){????????????g_CliSocketArr[i--]?=?g_CliSocketArr[--g_iTotalConn];}}else{szMessage[ret]?=?'\0';send(g_CliSocketArr[i],?szMessage,?strlen(szMessage),?0);}}}}return?0; }

?服務(wù)器的幾個(gè)主要?jiǎng)幼魅缦?#xff1a;
??? ????1.創(chuàng)建監(jiān)聽套接字,綁定,監(jiān)聽;
??? ????2.創(chuàng)建工作者線程;
??? ????3.創(chuàng)建一個(gè)套接字?jǐn)?shù)組,用來存放當(dāng)前所有活動(dòng)的客戶端套接字,每accept一個(gè)連接就更新一次數(shù)組;
??? ????4.接受客戶端的連接。這里有一點(diǎn)需要注意的,就是我沒有重新定義FD_SETSIZE宏,所以服務(wù)器最多支持的并發(fā)連接數(shù)為64。而且,這里決不能無(wú)條件的accept,服務(wù)器應(yīng)該根據(jù)當(dāng)前的連接數(shù)來決定是否接受來自某個(gè)客戶端的連接。一種比較好的實(shí)現(xiàn)方案就是采用WSAAccept函數(shù),而且讓W(xué)SAAccept回調(diào)自己實(shí)現(xiàn)的Condition Function。

工作者線程里面是一個(gè)死循環(huán),一次循環(huán)完成的動(dòng)作是:
??? ????1.將當(dāng)前所有的客戶端套接字加入到讀集fdread中;
??? ????2.調(diào)用select函數(shù);
??? ????3.查看某個(gè)套接字是否仍然處于


讀集中,如果是,則接收數(shù)據(jù)。如果接收的數(shù)據(jù)長(zhǎng)度為0,或者發(fā)生WSAECONNRESET錯(cuò)誤,則表示客戶端套接字主動(dòng)關(guān)閉,這時(shí)需要將服務(wù)器中對(duì)應(yīng)的套接字所綁定的資源釋放掉,然后調(diào)整我們的套接字?jǐn)?shù)組(將數(shù)組中最后一個(gè)套接字挪到當(dāng)前的位置上)

???????除了需要有條件接受客戶端的連接外,還需要在連接數(shù)為0的情形下做特殊處理,因?yàn)槿绻x集中沒有任何套接字,select函數(shù)會(huì)立刻返回,這將導(dǎo)致工作者線程成為一個(gè)毫無(wú)停頓的死循環(huán),CPU的占用率馬上達(dá)到100%。

?二.異步選擇
??? ????Winsock提供了一個(gè)有用的異步I/O模型。利用這個(gè)模型,應(yīng)用程序可在一個(gè)套接字上,接收以Windows消息為基礎(chǔ)的網(wǎng)絡(luò)事件通知。具體的做法是在建好一個(gè)套接字后,調(diào)用WSAAsyncSelect函數(shù)。在它們用一個(gè)標(biāo)準(zhǔn)的Windows例程,對(duì)窗口消息進(jìn)行管理的時(shí)候使用比較好。

#include?<winsock.h> #include?<tchar.h> #define?PORT??????5150 #define?MSGSIZE???1024 #define?WM_SOCKET?WM_USER+0 #pragma?comment(lib,?"ws2_32.lib") LRESULT?CALLBACK?WndProc(HWND,?UINT,?WPARAM,?LPARAM); int?WINAPI?WinMain(HINSTANCE?hInstance,?HINSTANCE?hPrevInstance,?PSTR?szCmdLine,?int?iCmdShow) {static?TCHAR?szAppName[]?=?_T("AsyncSelect?Model");HWND?????????hwnd?;MSG??????????msg?;WNDCLASS?????wndclass?;wndclass.style?????????=?CS_HREDRAW?|?CS_VREDRAW?;wndclass.lpfnWndProc???=?WndProc?;wndclass.cbClsExtra????=?0?;wndclass.cbWndExtra????=?0?;wndclass.hInstance?????=?hInstance?;wndclass.hIcon?????????=?LoadIcon?(NULL,?IDI_APPLICATION)?;wndclass.hCursor???????=?LoadCursor?(NULL,?IDC_ARROW)?;wndclass.hbrBackground?=?(HBRUSH)?GetStockObject?(WHITE_BRUSH)?;wndclass.lpszMenuName??=?NULL?;wndclass.lpszClassName?=?szAppName?;if?(!RegisterClass(&wndclass)){MessageBox?(NULL,?TEXT?("This?program?requires?Windows?NT!"),?szAppName,?MB_ICONERROR)?;return?0?;}hwnd?=?CreateWindow?(szAppName,??????????????????//?window?class?nameTEXT?("AsyncSelect?Model"),?//?window?captionWS_OVERLAPPEDWINDOW,????????//?window?styleCW_USEDEFAULT,??????????????//?initial?x?positionCW_USEDEFAULT,??????????????//?initial?y?positionCW_USEDEFAULT,??????????????//?initial?x?sizeCW_USEDEFAULT,??????????????//?initial?y?sizeNULL,???????????????????????//?parent?window?handleNULL,???????????????????????//?window?menu?handlehInstance,??????????????????//?program?instance?handleNULL)?;?????????????????????//?creation?parametersShowWindow(hwnd,?iCmdShow);UpdateWindow(hwnd);while?(GetMessage(&msg,?NULL,?0,?0)){TranslateMessage(&msg)?;DispatchMessage(&msg)?;}return?msg.wParam; } LRESULT?CALLBACK?WndProc?(HWND?hwnd,?UINT?message,?WPARAM?wParam,?LPARAM?lParam) {WSADATA???????wsd;static?SOCKET?sListen;SOCKET????????sClient;SOCKADDR_IN???local,?client;int???????????ret,?iAddrSize?=?sizeof(client);char??????????szMessage[MSGSIZE];switch?(message){case?WM_CREATE://?Initialize?Windows?Socket?libraryWSAStartup(0x0202,?&wsd);//?Create?listening?socketsListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);//?Bindlocal.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(local));//?Listenlisten(sListen,?3);//?Associate?listening?socket?with?FD_ACCEPT?eventWSAAsyncSelect(sListen,?hwnd,?WM_SOCKET,?FD_ACCEPT);return?0;case?WM_DESTROY:closesocket(sListen);WSACleanup();PostQuitMessage(0);return?0;case?WM_SOCKET:if?(WSAGETSELECTERROR(lParam)){closesocket(wParam);break;}switch?(WSAGETSELECTEVENT(lParam)){case?FD_ACCEPT://?Accept?a?connection?from?clientsClient?=?accept(wParam,?(struct?sockaddr?*)&client,?&iAddrSize);//?Associate?client?socket?with?FD_READ?and?FD_CLOSE?eventWSAAsyncSelect(sClient,?hwnd,?WM_SOCKET,?FD_READ?|?FD_CLOSE);break;case?FD_READ:ret?=?recv(wParam,?szMessage,?MSGSIZE,?0);if?(ret?==?0?||?ret?==?SOCKET_ERROR?&&?WSAGetLastError()?==?WSAECONNRESET){closesocket(wParam);}else{szMessage[ret]?=?'\0';send(wParam,?szMessage,?strlen(szMessage),?0);}break;case?FD_CLOSE:closesocket(wParam);??????break;}return?0;}return?DefWindowProc(hwnd,?message,?wParam,?lParam); }

在我看來,WSAAsyncSelect是最簡(jiǎn)單的一種Winsock I/O模型(因?yàn)橐粋€(gè)主線程就搞定了)。使用RawWindows API寫過窗口類應(yīng)用程序的人應(yīng)該都能看得懂。這里,我們需要做的僅僅是:
??? ????1.在WM_CREATE消息處理函數(shù)中,初始化Windows Socket library,創(chuàng)建監(jiān)聽套接字,綁定,監(jiān)聽,并且調(diào)用WSAAsyncSelect函數(shù)表示我們關(guān)心在監(jiān)聽套接字上發(fā)生的FD_ACCEPT事件;
??? ????2.自定義一個(gè)消息WM_SOCKET,一旦在我們所關(guān)心的套接字(監(jiān)聽套接字和客戶端套接字)上發(fā)生了某個(gè)事件,系統(tǒng)就會(huì)調(diào)用WndProc并且message參數(shù)被設(shè)置為WM_SOCKET;
??? ????3.在WM_SOCKET的消息處理函數(shù)中,分別對(duì)FD_ACCEPT、FD_READ和FD_CLOSE事件進(jìn)行處理;
??? ????4.在窗口銷毀消息(WM_DESTROY)的處理函數(shù)中,我們關(guān)閉監(jiān)聽套接字,清除Windows Socket library。

三.事件選擇
??? ????Winsock提供了另一個(gè)有用的異步I/O模型。和WSAAsyncSelect模型類似的是,它也允許應(yīng)用程序在一個(gè)或多個(gè)套接字上,接收以事件為基礎(chǔ)的網(wǎng)絡(luò)事件通知。由WSAAsyncSelect模型采用的網(wǎng)絡(luò)事件來說,它們均可原封不動(dòng)地移植到新模型。在用新模型開發(fā)的應(yīng)用程序中,也能接收和處理所有那些事件。該模型最主要的差別在于網(wǎng)絡(luò)事件會(huì)投遞至一個(gè)事件對(duì)象句柄,而非投遞至一個(gè)窗口例程。

#include?<winsock2.h> #include?<stdio.h> #define?PORT????5150 #define?MSGSIZE?1024 #pragma?comment(lib,?"ws2_32.lib") int??????g_iTotalConn?=?0; SOCKET???g_CliSocketArr[MAXIMUM_WAIT_OBJECTS]; WSAEVENT?g_CliEventArr[MAXIMUM_WAIT_OBJECTS]; DWORD?WINAPI?WorkerThread(LPVOID); void?Cleanup(int?index); int?main() {WSADATA?????wsaData;SOCKET??????sListen,?sClient;SOCKADDR_IN?local,?client;DWORD???????dwThreadId;int?????????iaddrSize?=?sizeof(SOCKADDR_IN);//?Initialize?Windows?Socket?libraryWSAStartup(0x0202,?&wsaData);//?Create?listening?socketsListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);//?Bindlocal.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(SOCKADDR_IN));//?Listenlisten(sListen,?3);//?Create?worker?threadCreateThread(NULL,?0,?WorkerThread,?NULL,?0,?&dwThreadId);while?(TRUE){//?Accept?a?connectionsClient?=?accept(sListen,?(struct?sockaddr?*)&client,?&iaddrSize);printf("Accepted?client:%s:%d\n",?inet_ntoa(client.sin_addr),?ntohs(client.sin_port));//?Associate?socket?with?network?eventg_CliSocketArr[g_iTotalConn]?=?sClient;g_CliEventArr[g_iTotalConn]?=?WSACreateEvent();WSAEventSelect(g_CliSocketArr[g_iTotalConn],?g_CliEventArr[g_iTotalConn],?FD_READ?|?FD_CLOSE);g_iTotalConn++;} } DWORD?WINAPI?WorkerThread(LPVOID?lpParam) {int??????????????ret,?index;WSANETWORKEVENTS?NetworkEvents;char?????????????szMessage[MSGSIZE];while?(TRUE){ret?=?WSAWaitForMultipleEvents(g_iTotalConn,?g_CliEventArr,?FALSE,?1000,?FALSE);if?(ret?==?WSA_WAIT_FAILED?||?ret?==?WSA_WAIT_TIMEOUT){continue;}index?=?ret?-?WSA_WAIT_EVENT_0;WSAEnumNetworkEvents(g_CliSocketArr[index],?g_CliEventArr[index],?&NetworkEvents);if?(NetworkEvents.lNetworkEvents?&?FD_READ){//?Receive?message?from?clientret?=?recv(g_CliSocketArr[index],?szMessage,?MSGSIZE,?0);if?(ret?==?0?||?(ret?==?SOCKET_ERROR?&&?WSAGetLastError()?==?WSAECONNRESET)){Cleanup(index);}else{szMessage[ret]?=?'\0';send(g_CliSocketArr[index],?szMessage,?strlen(szMessage),?0);}}if?(NetworkEvents.lNetworkEvents?&?FD_CLOSE){Cleanup(index);}}return?0; } void?Cleanup(int?index) {closesocket(g_CliSocketArr[index]);WSACloseEvent(g_CliEventArr[index]);if?(index?<?g_iTotalConn?-?1){g_CliSocketArr[index]?=?g_CliSocketArr[g_iTotalConn?-?1];g_CliEventArr[index]?=?g_CliEventArr[g_iTotalConn?-?1];}g_iTotalConn--; }

事件選擇模型也比較簡(jiǎn)單,實(shí)現(xiàn)起來也不是太復(fù)雜,它的基本思想是將每個(gè)套接字都和一個(gè)WSAEVENT對(duì)象對(duì)應(yīng)起來,并且在關(guān)聯(lián)的時(shí)候指定需要關(guān)注的哪些網(wǎng)絡(luò)事件。一旦在某個(gè)套接字上發(fā)生了我們關(guān)注的事件(FD_READ和FD_CLOSE),與之相關(guān)聯(lián)的WSAEVENT對(duì)象被Signaled。程序定義了兩個(gè)全局?jǐn)?shù)組,一個(gè)套接字?jǐn)?shù)組,一個(gè)WSAEVENT對(duì)象數(shù)組,其大小都是MAXIMUM_WAIT_OBJECTS(64),兩個(gè)數(shù)組中的元素一一對(duì)應(yīng)。
??? ????同樣的,這里的程序沒有考慮兩個(gè)問題,一是不能無(wú)條件的調(diào)用accept,因?yàn)槲覀冎С值牟l(fā)連接數(shù)有限。解決方法是將套接字按MAXIMUM_WAIT_OBJECTS分組,每MAXIMUM_WAIT_OBJECTS個(gè)套接字一組,每一組分配一個(gè)工作者線程;或者采用WSAAccept代替accept,并回調(diào)自己定義的Condition Function。第二個(gè)問題是沒有對(duì)連接數(shù)為0的情形做特殊處理,程序在連接數(shù)為0的時(shí)候CPU占用率為100%。

四.重疊I/O模型
??? ????Winsock2的發(fā)布使得Socket I/O有了和文件I/O統(tǒng)一的接口。我們可以通過使用Win32文件操縱函數(shù)ReadFile和WriteFile來進(jìn)行Socket I/O。伴隨而來的,用于普通文件I/O的重疊I/O模型和完成端口模型對(duì)Socket I/O也適用了。這些模型的優(yōu)點(diǎn)是可以達(dá)到更佳的系統(tǒng)性能,但是實(shí)現(xiàn)較為復(fù)雜,里面涉及較多的C語(yǔ)言技巧。例如我們?cè)谕瓿啥丝谀P椭袝?huì)經(jīng)常用到所謂的“尾隨數(shù)據(jù)”。

?1.用事件通知方式實(shí)現(xiàn)的重疊I/O模型

#include?<winsock2.h> #include?<stdio.h> #define?PORT????5150 #define?MSGSIZE?1024 #pragma?comment(lib,?"ws2_32.lib") typedef?struct {WSAOVERLAPPED?overlap;WSABUF????????Buffer;char??????????szMessage[MSGSIZE];DWORD?????????NumberOfBytesRecvd;DWORD?????????Flags; }PER_IO_OPERATION_DATA,?*LPPER_IO_OPERATION_DATA; int?????????????????????g_iTotalConn?=?0; SOCKET??????????????????g_CliSocketArr[MAXIMUM_WAIT_OBJECTS]; WSAEVENT????????????????g_CliEventArr[MAXIMUM_WAIT_OBJECTS]; LPPER_IO_OPERATION_DATA?g_pPerIODataArr[MAXIMUM_WAIT_OBJECTS]; DWORD?WINAPI?WorkerThread(LPVOID); void?Cleanup(int); int?main() {WSADATA?????wsaData;SOCKET??????sListen,?sClient;SOCKADDR_IN?local,?client;DWORD???????dwThreadId;int?????????iaddrSize?=?sizeof(SOCKADDR_IN);//?Initialize?Windows?Socket?libraryWSAStartup(0x0202,?&wsaData);//?Create?listening?socketsListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);//?Bindlocal.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(SOCKADDR_IN));//?Listenlisten(sListen,?3);//?Create?worker?threadCreateThread(NULL,?0,?WorkerThread,?NULL,?0,?&dwThreadId);while?(TRUE){//?Accept?a?connectionsClient?=?accept(sListen,?(struct?sockaddr?*)&client,?&iaddrSize);printf("Accepted?client:%s:%d\n",?inet_ntoa(client.sin_addr),?ntohs(client.sin_port));g_CliSocketArr[g_iTotalConn]?=?sClient;//?Allocate?a?PER_IO_OPERATION_DATA?structureg_pPerIODataArr[g_iTotalConn]?=?(LPPER_IO_OPERATION_DATA)HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,sizeof(PER_IO_OPERATION_DATA));g_pPerIODataArr[g_iTotalConn]->Buffer.len?=?MSGSIZE;g_pPerIODataArr[g_iTotalConn]->Buffer.buf?=?g_pPerIODataArr[g_iTotalConn]->szMessage;g_CliEventArr[g_iTotalConn]?=?g_pPerIODataArr[g_iTotalConn]->overlap.hEvent?=?WSACreateEvent();//?Launch?an?asynchronous?operationWSARecv(g_CliSocketArr[g_iTotalConn],&g_pPerIODataArr[g_iTotalConn]->Buffer,1,&g_pPerIODataArr[g_iTotalConn]->NumberOfBytesRecvd,&g_pPerIODataArr[g_iTotalConn]->Flags,&g_pPerIODataArr[g_iTotalConn]->overlap,NULL);g_iTotalConn++;}closesocket(sListen);WSACleanup();return?0; } DWORD?WINAPI?WorkerThread(LPVOID?lpParam) {int???ret,?index;DWORD?cbTransferred;while?(TRUE){ret?=?WSAWaitForMultipleEvents(g_iTotalConn,?g_CliEventArr,?FALSE,?1000,?FALSE);if?(ret?==?WSA_WAIT_FAILED?||?ret?==?WSA_WAIT_TIMEOUT){continue;}index?=?ret?-?WSA_WAIT_EVENT_0;WSAResetEvent(g_CliEventArr[index]);WSAGetOverlappedResult(g_CliSocketArr[index],&g_pPerIODataArr[index]->overlap,&cbTransferred,TRUE,&g_pPerIODataArr[g_iTotalConn]->Flags);if?(cbTransferred?==?0){//?The?connection?was?closed?by?clientCleanup(index);}else{//?g_pPerIODataArr[index]->szMessage?contains?the?received?datag_pPerIODataArr[index]->szMessage[cbTransferred]?=?'\0';send(g_CliSocketArr[index],?g_pPerIODataArr[index]->szMessage,\cbTransferred,?0);//?Launch?another?asynchronous?operationWSARecv(g_CliSocketArr[index],&g_pPerIODataArr[index]->Buffer,1,&g_pPerIODataArr[index]->NumberOfBytesRecvd,&g_pPerIODataArr[index]->Flags,&g_pPerIODataArr[index]->overlap,NULL);}}return?0; } void?Cleanup(int?index) {closesocket(g_CliSocketArr[index]);WSACloseEvent(g_CliEventArr[index]);HeapFree(GetProcessHeap(),?0,?g_pPerIODataArr[index]);if?(index?<?g_iTotalConn?-?1){g_CliSocketArr[index]?=?g_CliSocketArr[g_iTotalConn?-?1];g_CliEventArr[index]?=?g_CliEventArr[g_iTotalConn?-?1];g_pPerIODataArr[index]?=?g_pPerIODataArr[g_iTotalConn?-?1];}g_pPerIODataArr[--g_iTotalConn]?=?NULL; }

這個(gè)模型與上述其他模型不同的是它使用Winsock2提供的異步I/O函數(shù)WSARecv。在調(diào)用WSARecv時(shí),指定一個(gè)WSAOVERLAPPED結(jié)構(gòu),這個(gè)調(diào)用不是阻塞的,也就是說,它會(huì)立刻返回。一旦有數(shù)據(jù)到達(dá)的時(shí)候,被指定的WSAOVERLAPPED結(jié)構(gòu)中的hEvent被Signaled。由于下面這個(gè)語(yǔ)句
??? ????g_CliEventArr[g_iTotalConn] = g_pPerIODataArr[g_iTotalConn]->overlap.hEvent;
??? ????使得與該套接字相關(guān)聯(lián)的WSAEVENT對(duì)象也被Signaled,所以WSAWaitForMultipleEvents的調(diào)用操作成功返回。我們現(xiàn)在應(yīng)該做的就是用與調(diào)用WSARecv相同的WSAOVERLAPPED結(jié)構(gòu)為參數(shù)調(diào)用WSAGetOverlappedResult,從而得到本次I/O傳送的字節(jié)數(shù)等相關(guān)信息。在取得接收的數(shù)據(jù)后,把數(shù)據(jù)原封不動(dòng)的發(fā)送到客戶端,然后重新激活一個(gè)WSARecv異步操作。

2.用完成例程方式實(shí)現(xiàn)的重疊I/O模型

#include?<WINSOCK2.H> #include?<stdio.h> #define?PORT????5150 #define?MSGSIZE?1024 #pragma?comment(lib,?"ws2_32.lib") typedef?struct {WSAOVERLAPPED?overlap;WSABUF????????Buffer;char??????????szMessage[MSGSIZE];DWORD?????????NumberOfBytesRecvd;DWORD?????????Flags;?SOCKET????????sClient; }PER_IO_OPERATION_DATA,?*LPPER_IO_OPERATION_DATA; DWORD?WINAPI?WorkerThread(LPVOID); void?CALLBACK?CompletionROUTINE(DWORD,?DWORD,?LPWSAOVERLAPPED,?DWORD); SOCKET?g_sNewClientConnection; BOOL???g_bNewConnectionArrived?=?FALSE; int?main() {WSADATA?????wsaData;SOCKET??????sListen;SOCKADDR_IN?local,?client;DWORD???????dwThreadId;int?????????iaddrSize?=?sizeof(SOCKADDR_IN);//?Initialize?Windows?Socket?libraryWSAStartup(0x0202,?&wsaData);//?Create?listening?socketsListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);//?Bindlocal.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(SOCKADDR_IN));//?Listenlisten(sListen,?3);//?Create?worker?threadCreateThread(NULL,?0,?WorkerThread,?NULL,?0,?&dwThreadId);while?(TRUE){//?Accept?a?connectiong_sNewClientConnection?=?accept(sListen,?(struct?sockaddr?*)&client,?&iaddrSize);g_bNewConnectionArrived?=?TRUE;printf("Accepted?client:%s:%d\n",?inet_ntoa(client.sin_addr),?ntohs(client.sin_port));} } DWORD?WINAPI?WorkerThread(LPVOID?lpParam) {LPPER_IO_OPERATION_DATA?lpPerIOData?=?NULL;while?(TRUE){if?(g_bNewConnectionArrived){//?Launch?an?asynchronous?operation?for?new?arrived?connectionlpPerIOData?=?(LPPER_IO_OPERATION_DATA)HeapAlloc(GetProcessHeap(),?HEAP_ZERO_MEMORY,?sizeof(PER_IO_OPERATION_DATA));lpPerIOData->Buffer.len?=?MSGSIZE;lpPerIOData->Buffer.buf?=?lpPerIOData->szMessage;lpPerIOData->sClient?=?g_sNewClientConnection;WSARecv(lpPerIOData->sClient,?&lpPerIOData->Buffer,1,&lpPerIOData->NumberOfBytesRecvd,&lpPerIOData->Flags,&lpPerIOData->overlap,CompletionROUTINE);??????g_bNewConnectionArrived?=?FALSE;}SleepEx(1000,?TRUE);}return?0; } void?CALLBACK?CompletionROUTINE(DWORD?dwError,DWORD?cbTransferred,LPWSAOVERLAPPED?lpOverlapped,DWORD?dwFlags) {LPPER_IO_OPERATION_DATA?lpPerIOData?=?(LPPER_IO_OPERATION_DATA)lpOverlapped;if?(dwError?!=?0?||?cbTransferred?==?0){//?Connection?was?closed?by?clientclosesocket(lpPerIOData->sClient);HeapFree(GetProcessHeap(),?0,?lpPerIOData);}else{lpPerIOData->szMessage[cbTransferred]?=?'\0';send(lpPerIOData->sClient,?lpPerIOData->szMessage,?cbTransferred,?0);//?Launch?another?asynchronous?operationmemset(&lpPerIOData->overlap,?0,?sizeof(WSAOVERLAPPED));lpPerIOData->Buffer.len?=?MSGSIZE;lpPerIOData->Buffer.buf?=?lpPerIOData->szMessage;????WSARecv(lpPerIOData->sClient,&lpPerIOData->Buffer,1,&lpPerIOData->NumberOfBytesRecvd,&lpPerIOData->Flags,&lpPerIOData->overlap,CompletionROUTINE);} }

用完成例程來實(shí)現(xiàn)重疊I/O比用事件通知簡(jiǎn)單得多。在這個(gè)模型中,主線程只用不停的接受連接即可;輔助線程判斷有沒有新的客戶端連接被建立,如果有,就為那個(gè)客戶端套接字激活一個(gè)異步的WSARecv操作,然后調(diào)用SleepEx使線程處于一種可警告的等待狀態(tài),以使得I/O完成后CompletionROUTINE可以被內(nèi)核調(diào)用。如果輔助線程不調(diào)用SleepEx,則內(nèi)核在完成一次I/O操作后,無(wú)法調(diào)用完成例程(因?yàn)橥瓿衫痰倪\(yùn)行應(yīng)該和當(dāng)初激活WSARecv異步操作的代碼在同一個(gè)線程之內(nèi))。
??? ????完成例程內(nèi)的實(shí)現(xiàn)代碼比較簡(jiǎn)單,它取出接收到的數(shù)據(jù),然后將數(shù)據(jù)原封不動(dòng)的發(fā)送給客戶端,最后重新激活另一個(gè)WSARecv異步操作。注意,在這里用到了“尾隨數(shù)據(jù)”。我們?cè)谡{(diào)用WSARecv的時(shí)候,參數(shù)lpOverlapped實(shí)際上指向一個(gè)比它大得多的結(jié)構(gòu)PER_IO_OPERATION_DATA,這個(gè)結(jié)構(gòu)除了WSAOVERLAPPED以外,還被我們附加了緩沖區(qū)的結(jié)構(gòu)信息,另外還包括客戶端套接字等重要的信息。這樣,在完成例程中通過參數(shù)lpOverlapped拿到的不僅僅是WSAOVERLAPPED結(jié)構(gòu),還有后邊尾隨的包含客戶端套接字和接收數(shù)據(jù)緩沖區(qū)等重要信息。這樣的C語(yǔ)言技巧在我后面介紹完成端口的時(shí)候還會(huì)使用到。

五.完成端口模型
??? ????“完成端口”模型是迄今為止最為復(fù)雜的一種I/O模型。然而,假若一個(gè)應(yīng)用程序同時(shí)需要管理為數(shù)眾多的套接字,那么采用這種模型,往往可以達(dá)到最佳的系統(tǒng)性能!但不幸的是,該模型只適用于Windows NT和Windows 2000操作系統(tǒng)。因其設(shè)計(jì)的復(fù)雜性,只有在你的應(yīng)用程序需要同時(shí)管理數(shù)百乃至上千個(gè)套接字的時(shí)候,而且希望隨著系統(tǒng)內(nèi)安裝的CPU數(shù)量的增多,應(yīng)用程序的性能也可以線性提升,才應(yīng)考慮采用“完成端口”模型。要記住的一個(gè)基本準(zhǔn)則是,假如要為Windows NT或Windows 2000開發(fā)高性能的服務(wù)器應(yīng)用,同時(shí)希望為大量套接字I/O請(qǐng)求提供服務(wù)(Web服務(wù)器便是這方面的典型例子),那么I/O完成端口模型便是最佳選擇!
??? ????完成端口模型是我最喜愛的一種模型。雖然其實(shí)現(xiàn)比較復(fù)雜(其實(shí)我覺得它的實(shí)現(xiàn)比用事件通知實(shí)現(xiàn)的重疊I/O簡(jiǎn)單多了),但其效率是驚人的。完成端口模型在多連接(成千上萬(wàn))的情況下,僅僅依靠一兩個(gè)輔助線程,就可以達(dá)到非常高的吞吐量。

#include?<WINSOCK2.H> #include?<stdio.h> #define?PORT????5150 #define?MSGSIZE?1024 #pragma?comment(lib,?"ws2_32.lib") typedef?enum {RECV_POSTED }OPERATION_TYPE; typedef?struct {WSAOVERLAPPED??overlap;WSABUF?????????Buffer;char???????????szMessage[MSGSIZE];DWORD??????????NumberOfBytesRecvd;DWORD??????????Flags;OPERATION_TYPE?OperationType; }PER_IO_OPERATION_DATA,?*LPPER_IO_OPERATION_DATA; DWORD?WINAPI?WorkerThread(LPVOID); int?main() {WSADATA?????????????????wsaData;SOCKET??????????????????sListen,?sClient;SOCKADDR_IN?????????????local,?client;DWORD???????????????????i,?dwThreadId;int?????????????????????iaddrSize?=?sizeof(SOCKADDR_IN);HANDLE??????????????????CompletionPort?=?INVALID_HANDLE_VALUE;SYSTEM_INFO?????????????systeminfo;LPPER_IO_OPERATION_DATA?lpPerIOData?=?NULL;//?Initialize?Windows?Socket?libraryWSAStartup(0x0202,?&wsaData);//?Create?completion?portCompletionPort?=?CreateIoCompletionPort(INVALID_HANDLE_VALUE,?NULL,?0,?0);//?Create?worker?threadGetSystemInfo(&systeminfo);for?(i?=?0;?i?<?systeminfo.dwNumberOfProcessors;?i++){CreateThread(NULL,?0,?WorkerThread,?CompletionPort,?0,?&dwThreadId);}//?Create?listening?socketsListen?=?socket(AF_INET,?SOCK_STREAM,?IPPROTO_TCP);//?Bindlocal.sin_addr.S_un.S_addr?=?htonl(INADDR_ANY);local.sin_family?=?AF_INET;local.sin_port?=?htons(PORT);bind(sListen,?(struct?sockaddr?*)&local,?sizeof(SOCKADDR_IN));//?Listenlisten(sListen,?3);while?(TRUE){//?Accept?a?connectionsClient?=?accept(sListen,?(struct?sockaddr?*)&client,?&iaddrSize);printf("Accepted?client:%s:%d\n",?inet_ntoa(client.sin_addr),?ntohs(client.sin_port));//?Associate?the?newly?arrived?client?socket?with?completion?portCreateIoCompletionPort((HANDLE)sClient,?CompletionPort,?(DWORD)sClient,?0);//?Launch?an?asynchronous?operation?for?new?arrived?connectionlpPerIOData?=?(LPPER_IO_OPERATION_DATA)HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,sizeof(PER_IO_OPERATION_DATA));lpPerIOData->Buffer.len?=?MSGSIZE;lpPerIOData->Buffer.buf?=?lpPerIOData->szMessage;lpPerIOData->OperationType?=?RECV_POSTED;WSARecv(sClient,&lpPerIOData->Buffer,1,&lpPerIOData->NumberOfBytesRecvd,&lpPerIOData->Flags,&lpPerIOData->overlap,NULL);}PostQueuedCompletionStatus(CompletionPort,?0xFFFFFFFF,?0,?NULL);CloseHandle(CompletionPort);closesocket(sListen);WSACleanup();return?0; } DWORD?WINAPI?WorkerThread(LPVOID?CompletionPortID) {HANDLE??????????????????CompletionPort=(HANDLE)CompletionPortID;DWORD???????????????????dwBytesTransferred;SOCKET??????????????????sClient;LPPER_IO_OPERATION_DATA?lpPerIOData?=?NULL;while?(TRUE){GetQueuedCompletionStatus(CompletionPort,&dwBytesTransferred,&sClient,(LPOVERLAPPED?*)&lpPerIOData,INFINITE);if?(dwBytesTransferred?==?0xFFFFFFFF){return?0;}if?(lpPerIOData->OperationType?==?RECV_POSTED){if?(dwBytesTransferred?==?0){//?Connection?was?closed?by?clientclosesocket(sClient);HeapFree(GetProcessHeap(),?0,?lpPerIOData);????????}else{lpPerIOData->szMessage[dwBytesTransferred]?=?'\0';send(sClient,?lpPerIOData->szMessage,?dwBytesTransferred,?0);//?Launch?another?asynchronous?operation?for?sClientmemset(lpPerIOData,?0,?sizeof(PER_IO_OPERATION_DATA));lpPerIOData->Buffer.len?=?MSGSIZE;lpPerIOData->Buffer.buf?=?lpPerIOData->szMessage;lpPerIOData->OperationType?=?RECV_POSTED;WSARecv(sClient,&lpPerIOData->Buffer,1,&lpPerIOData->NumberOfBytesRecvd,&lpPerIOData->Flags,&lpPerIOData->overlap,NULL);}}}return?0; }

首先,說說主線程:
??? ????1.創(chuàng)建完成端口對(duì)象
??? ????2.創(chuàng)建工作者線程(這里工作者線程的數(shù)量是按照CPU的個(gè)數(shù)來決定的,這樣可以達(dá)到最佳性能)
??? ????3.創(chuàng)建監(jiān)聽套接字,綁定,監(jiān)聽,然后程序進(jìn)入循環(huán)
??? ????4.在循環(huán)中,我做了以下幾件事情:
??? ???????????(1).接受一個(gè)客戶端連接
??? ???????????(2).將該客戶端套接字與完成端口綁定到一起(還是調(diào)用CreateIoCompletionPort,但這次的作用不同),注意,按道理來講,此時(shí)傳遞給CreateIoCompletionPort的第三個(gè)參數(shù)應(yīng)該是一個(gè)完成鍵,一般來講,程序都是傳遞一個(gè)單句柄數(shù)據(jù)結(jié)構(gòu)的地址,該單句柄數(shù)據(jù)包含了和該客戶端連接有關(guān)的信息,由于我們只關(guān)心套接字句柄,所以直接將套接字句柄作為完成鍵傳遞;
??? ???????????(3).觸發(fā)一個(gè)WSARecv異步調(diào)用,這次又用到了“尾隨數(shù)據(jù)”,使接收數(shù)據(jù)所用的緩沖區(qū)緊跟在WSAOVERLAPPED對(duì)象之后,此外,還有操作類型等重要信息。
??? ????在工作者線程的循環(huán)中,我們
??? ????1.調(diào)用GetQueuedCompletionStatus取得本次I/O的相關(guān)信息(例如套接字句柄、傳送的字節(jié)數(shù)、單I/O數(shù)據(jù)結(jié)構(gòu)的地址等等)
??? ????2.通過單I/O數(shù)據(jù)結(jié)構(gòu)找到接收數(shù)據(jù)緩沖區(qū),然后將數(shù)據(jù)原封不動(dòng)的發(fā)送到客戶端
??? ????3.再次觸發(fā)一個(gè)WSARecv異步操作

?五種I/O模型的比較
??? ????我會(huì)從以下幾個(gè)方面來進(jìn)行比較
??? ????*有無(wú)每線程64連接數(shù)限制
??? ????如果在選擇模型中沒有重新定義FD_SETSIZE宏,則每個(gè)fd_set默認(rèn)可以裝下64個(gè)SOCKET。同樣的,受MAXIMUM_WAIT_OBJECTS宏的影響,事件選擇、用事件通知實(shí)現(xiàn)的重疊I/O都有每線程最大64連接數(shù)限制。如果連接數(shù)成千上萬(wàn),則必須對(duì)客戶端套接字進(jìn)行分組,這樣,勢(shì)必增加程序的復(fù)雜度。
??? ????相反,異步選擇、用完成例程實(shí)現(xiàn)的重疊I/O和完成端口不受此限制。

???????*線程數(shù)
??? ????除了異步選擇以外,其他模型至少需要2個(gè)線程。一個(gè)主線程和一個(gè)輔助線程。同樣的,如果連接數(shù)大于64,則選擇模型、事件選擇和用事件通知實(shí)現(xiàn)的重疊I/O的線程數(shù)還要增加。

???????*實(shí)現(xiàn)的復(fù)雜度
??? ????我的個(gè)人看法是,在實(shí)現(xiàn)難度上,異步選擇<選擇<用完成例程實(shí)現(xiàn)的重疊I/O<事件選擇<完成端口<用事件通知實(shí)現(xiàn)的重疊I/O

??? ????*性能
??? ????由于選擇模型中每次都要重設(shè)讀集,在select函數(shù)返回后還要針對(duì)所有套接字進(jìn)行逐一測(cè)試,我的感覺是效率比較差;完成端口和用完成例程實(shí)現(xiàn)的重疊I/O基本上不涉及全局?jǐn)?shù)據(jù),效率應(yīng)該是最高的,而且在多處理器情形下完成端口還要高一些;事件選擇和用事件通知實(shí)現(xiàn)的重疊I/O在實(shí)現(xiàn)機(jī)制上都是采用WSAWaitForMultipleEvents,感覺效率差不多;至于異步選擇,不好比較。所以我的結(jié)論是:選擇<用事件通知實(shí)現(xiàn)的重疊I/O<事件選擇<用完成例程實(shí)現(xiàn)的重疊I/O<完成端口


轉(zhuǎn)載于:https://blog.51cto.com/20111564/1416745

總結(jié)

以上是生活随笔為你收集整理的Windows Socket五种I/O模型的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

久久久国产精品一区二区中文 | 天天操天天干天天爱 | 国产999精品久久久 免费a网站 | 日韩久久精品一区二区 | 欧美日韩高清在线观看 | 久久新 | 国产一级做a爱片久久毛片a | 99久久久国产精品免费99 | 中文字幕高清免费日韩视频在线 | 成人h视频在线播放 | 国产精品久久99综合免费观看尤物 | 国产资源在线视频 | 操操操av | 日韩久久精品一区二区三区下载 | 一区二区三区久久 | 久久在线电影 | 国产精品一区二区视频 | 亚洲最新av| 欧美另类交在线观看 | 国产成人av网站 | 337p日本大胆噜噜噜噜 | 黄色成品视频 | 精品久久免费看 | 国产一区二区高清视频 | 97国产 | 日韩精品第1页 | 久久久精品网站 | 五月黄色| 免费观看9x视频网站在线观看 | 亚洲精品中文字幕视频 | 欧美-第1页-屁屁影院 | 日韩一二区在线 | 日本成人黄色片 | 在线精品在线 | av电影中文字幕在线观看 | 亚洲精品中文字幕在线观看 | 涩av在线 | 色就是色综合 | 天天综合五月天 | 国产精品欧美一区二区 | 一区二区三区电影大全 | 国产精品久久久久久久久软件 | 91色蜜桃 | 不卡av电影在线 | 国产精品xxxx18a99 | 看毛片网站 | 国产精品久久久久久久久软件 | 欧美精品乱码久久久久久按摩 | 欧美午夜剧场 | 麻豆av一区二区三区在线观看 | 欧美精品免费在线观看 | 天天爽天天爽天天爽 | 黄色免费网站下载 | 婷婷精品在线 | 91精品在线观看入口 | 麻豆91精品视频 | 在线之家免费在线观看电影 | 在线日韩精品视频 | 成人a视频在线观看 | 中文字幕丝袜制服 | 亚洲综合在线一区二区三区 | 亚洲精品欧美专区 | 婷婷在线看 | 国产小视频精品 | 亚洲 中文 在线 精品 | 99久久精品无免国产免费 | 四虎国产精品成人免费4hu | 国产日产高清dvd碟片 | 久久久天堂 | 91桃色国产在线播放 | 国产一线二线三线在线观看 | 香蕉视频日本 | 亚洲精品小区久久久久久 | 五月婷婷视频在线 | 久久99精品久久久久久久久久久久 | 国产精品一区二区吃奶在线观看 | 婷婷在线网站 | 久久精品8 | 中文字幕中文字幕中文字幕 | 精品在线二区 | 色综合狠狠干 | 亚洲精品国偷自产在线99热 | 99热精品国产一区二区在线观看 | 亚洲精品美女视频 | 日韩精品免费在线播放 | 国产精品乱码久久久久 | 亚洲视频精品 | 精品在线免费观看 | 天天av综合网 | 天天干视频在线 | 激情久久久久久久久久久久久久久久 | 91大神精品视频在线观看 | a级片在线播放 | 欧美激情综合五月色丁香 | 不卡av在线 | 天天操夜夜摸 | 1000部18岁以下禁看视频 | 亚洲一区免费在线 | 国产伦理久久精品久久久久_ | 国产精品日韩欧美一区二区 | 黄色国产高清 | 99看视频在线观看 | 午夜久久久久久久久 | 精品久久久久亚洲 | 操碰av| 美女黄视频免费 | 美腿丝袜av| av在线一| av免费在线观看网站 | 国产麻豆精品传媒av国产下载 | 日韩在线网 | 久久黄色免费 | 亚洲午夜电影网 | 国产美女网 | 久草视频在线免费播放 | 日黄网站| 五月婷在线 | 久久高清国产 | 成人a视频在线观看 | 国产黄色av网站 | 在线免费视频a | 热久久国产 | 天天操天天操天天操天天操天天操天天操 | 久久99国产综合精品 | 在线小视频你懂的 | 永久免费精品视频网站 | 亚洲天堂精品视频在线观看 | 精品99在线视频 | 久久久久国产精品视频 | a在线播放| 91禁在线看 | 国内精品美女在线观看 | 精品麻豆入口免费 | 亚洲一区久久久 | 久久久久久国产精品 | 欧美亚洲久久 | 国产亚洲精品久久久久久 | 国产精品嫩草影院99网站 | 国产精品美女久久久久久久久 | 国产一级特黄毛片在线毛片 | 综合激情久久 | 国产精品第2页 | 九九九九精品 | 久久这里只有精品首页 | 久久精品在线视频 | 国产日韩av在线 | 超碰97免费在线 | 国产亚洲精品久久久久久电影 | 99精品影视 | 日韩欧美在线第一页 | 一级片视频在线 | 91精品国产入口 | 国产一区精品在线 | 亚州国产精品 | 99视频在线看 | 国产一线二线三线在线观看 | 99久久精品午夜一区二区小说 | 亚洲资源在线观看 | 在线观看中文字幕第一页 | 国产高清不卡av | 婷婷国产一区二区三区 | 国产二区视频在线 | 一本一本久久a久久精品综合小说 | 日本性动态图 | 久久99欧美 | 日韩精品一区在线观看 | 在线成人国产 | 国产精久久久久久妇女av | 成人丝袜 | 99精品久久久久久久久久综合 | 欧美做受xxx| 91色偷偷 | av电影中文| 97精品一区| 99精品在线观看 | av综合av| 91pony九色丨交换 | 成人三级黄色 | 国产精品刺激对白麻豆99 | 久久草精品| 成年人国产视频 | 久久视屏网 | 免费的黄色av | 一级免费看视频 | 久久久久国产一区二区 | 免费在线观看一级片 | 亚洲精品综合久久 | 国产精品美女久久久久久久久 | 麻花天美星空视频 | 日本中文字幕在线观看 | 亚洲视频每日更新 | 亚洲精品国产精品国自产 | 日韩欧美在线观看 | 欧美人体xx | 亚洲电影久久久 | 丁香婷婷久久久综合精品国产 | 久久久久国产成人精品亚洲午夜 | 亚洲精品电影在线 | 99精品国产福利在线观看免费 | 精品毛片在线 | 伊人狠狠干 | 99色亚洲 | 97色综合| 亚洲精品色视频 | 国产精品av免费在线观看 | a级片韩国 | 五月婷婷一区二区三区 | 国内精品久久久精品电影院 | 欧美极品xxx | 天天色天天干天天色 | 久久久免费精品国产一区二区 | 亚洲专区欧美专区 | 九九热只有这里有精品 | 婷婷在线五月 | 国产一区二区在线影院 | 国产精品女人久久久 | 欧美另类sm图片 | 精品国产诱惑 | 久久精品国产成人 | 国产精品久久久久久久久久久杏吧 | 亚洲一区二区观看 | 最新av在线网站 | 天天综合天天综合 | 国产视频中文字幕 | 极品嫩模被强到高潮呻吟91 | 日韩在线精品一区 | 亚洲欧美婷婷六月色综合 | 日韩簧片在线观看 | 国产成人精品在线 | 亚洲综合成人婷婷小说 | 亚洲视频www | 黄网在线免费观看 | 国产r级在线观看 | 日韩xxxbbb | 欧美成人一二区 | 久久久久久国产精品 | 久草在线免费看视频 | 中文字幕在线观看一区二区三区 | 精品 一区 在线 | 久久手机免费视频 | 日本午夜免费福利视频 | 亚洲天堂网视频 | 亚洲精品中文字幕视频 | japanese黑人亚洲人4k | av在线影片 | 激情开心色 | 91九色自拍| 中文字幕在线播放视频 | 亚洲激情在线播放 | 青春草视频在线播放 | 午夜久久久久久久久久影院 | 97精品一区| 超碰伊人网 | 国产亚洲成人网 | 亚洲人在线7777777精品 | 国产a级片免费观看 | 精品国产综合区久久久久久 | 91日韩在线视频 | 亚洲男模gay裸体gay | 国产成人一区二区在线观看 | 成人小电影在线看 | 天天射天天艹 | 日韩欧美视频免费观看 | 婷婷深爱激情 | 亚洲精品乱码久久久久久9色 | 中文字幕亚洲情99在线 | 91精品国产自产老师啪 | 国产在线观看不卡 | av免费观看高清 | 中文字幕在线播出 | 欧美一二三区播放 | 色综合久久88色综合天天6 | 亚洲二区精品 | 天天摸天天操天天舔 | 久草在线手机视频 | 激情五月***国产精品 | 亚洲最大免费成人网 | 三级黄色理论片 | 日韩欧美精品在线观看视频 | 精品久久久久久亚洲综合网站 | 色99在线| 欧美精品中文字幕亚洲专区 | 国产精品美 | 黄色网www | 一级一片免费看 | 欧美无极色 | 毛片888| 国产在线国偷精品产拍免费yy | 91插插插免费视频 | 观看免费av| 日韩在线观看第一页 | 精品在线视频一区 | 在线国产中文字幕 | 国产一级免费视频 | 婷婷四房综合激情五月 | av免费在线观看网站 | 久久99精品国产麻豆婷婷 | 中文字幕中文中文字幕 | 久久激情综合网 | 国产福利在线免费 | 国产精品欧美日韩在线观看 | 久久综合九色综合97婷婷女人 | 免费在线观看视频一区 | 探花视频免费观看高清视频 | 天天综合视频在线观看 | 99久久久国产免费 | 久久精品视频国产 | 人操人| 久久男女视频 | 日韩大片在线看 | 亚洲欧美在线视频免费 | 九精品 | 国产精品免费观看久久 | 久草视频在线免费 | 免费福利片 | 免费h视频 | 国产中文字幕久久 | 丁香婷婷网 | 国产剧在线观看片 | 91天天视频 | 天天艹天天干天天 | 国产不卡毛片 | 亚洲精品国偷自产在线99热 | 香蕉视频免费在线播放 | 亚洲1级片 | 夜夜视频资源 | 黄污视频网站 | 免费精品视频在线 | 毛片在线播放网址 | 91视频高清免费 | 亚洲另类xxxx | www.天天色.com | 国产免费视频一区二区裸体 | 亚洲一区 影院 | 欧美精品久久久久 | av片中文字幕 | 最新极品jizzhd欧美 | 麻豆传媒视频观看 | 久久国产精品一区二区三区 | av三级在线播放 | 亚洲国产精品一区二区久久,亚洲午夜 | 久久精品区 | 天天爽天天做 | 国产91免费观看 | 黄色av影院 | 国产乱码精品一区二区三区介绍 | av在线免费网 | 91自拍视频在线 | 五月婷婷丁香网 | 九九九免费视频 | 国产一级片免费观看 | 色噜噜日韩精品一区二区三区视频 | 成年人黄色大全 | 亚洲国产高清在线观看视频 | 国产三级视频在线 | 色婷婷综合久久久 | 国产剧情av在线播放 | 最近最新mv字幕免费观看 | 国产热re99久久6国产精品 | 亚洲精品视频网 | 国产精品久久久久久婷婷天堂 | 久久久久久久久久久免费av | 日韩视频中文 | 69精品在线观看 | 国产免费区 | 日本资源中文字幕在线 | 久久免费a | 中文字幕在线看片 | 免费观看9x视频网站在线观看 | 国产精品大片在线观看 | 久久精品一二区 | 中文字幕在线观看第一区 | 免费男女羞羞的视频网站中文字幕 | 久久视频在线观看免费 | 综合久久久久久久 | 亚洲精选视频在线 | 韩国av免费在线 | 久久久久久欧美二区电影网 | 久草精品视频在线播放 | 超碰97在线人人 | 久久综合狠狠综合久久综合88 | 九九在线精品视频 | 日韩av影视 | 国产精品成人免费精品自在线观看 | 在线播放亚洲激情 | 亚洲干视频在线观看 | 天天综合成人 | 天天爱天天射 | 91亚洲免费| 欧美色图30p | 在线免费观看视频你懂的 | 91在线小视频 | 国产成人精品一区二区三区在线 | 在线成人中文字幕 | 国产成人精品免费在线观看 | 久久精品一区二区三区国产主播 | 波多在线视频 | 天天躁天天狠天天透 | 色噜噜噜噜 | 亚洲精品电影在线 | 黄色小说在线观看视频 | 91爱在线 | 97中文字幕 | 欧美激情视频久久 | 天天爽天天爽夜夜爽 | 亚洲欧洲中文日韩久久av乱码 | 一级性av | 久久夜夜爽| 国产精品系列在线观看 | 在线一区av | 久久99精品久久久久蜜臀 | 国产精品久久久久久久久毛片 | 天天天天天干 | av黄色在线观看 | 精品久久久久久国产偷窥 | 国产精品久久久久久久午夜 | 国产亚洲精品久久久久动 | av资源网在线播放 | 婷婷国产在线观看 | 色婷婷国产精品一区在线观看 | 久久99国产综合精品免费 | 久草免费看 | 色婷婷免费视频 | 狠狠干我 | 特级黄录像视频 | 久香蕉 | 成人av视屏 | 日本中文字幕网站 | 天天玩天天操天天射 | 日韩和的一区二在线 | 亚洲成人频道 | 丝袜美腿在线播放 | 91精品久久久久久久91蜜桃 | a级一a一级在线观看 | 成人久久精品视频 | 久久夜靖品 | 中文字幕视频免费观看 | 亚洲免费婷婷 | 黄色成人毛片 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 婷婷五月色综合 | 视频福利在线观看 | 黄色电影网站在线观看 | 色综合天天做天天爱 | 麻豆91在线播放 | 日韩精品免费一线在线观看 | 久久久久一区二区三区四区 | 天天干婷婷 | 亚洲精品在线观看av | 中文字幕欧美日韩va免费视频 | 高清不卡毛片 | 中文字幕在线观看免费观看 | 欧美动漫一区二区三区 | 欧美在线18 | 欧美日韩国产一区二区三区在线观看 | 二区精品视频 | 免费一级片观看 | 97视频免费观看2区 亚洲视屏 | 亚洲精品乱码久久久久久9色 | 四虎成人av| 色多多污污在线观看 | 亚洲视频精品在线 | 久操中文字幕在线观看 | 亚洲精品在线观看网站 | 国产小视频国产精品 | 免费看片成年人 | 日韩网站在线看片你懂的 | av大片网址 | 麻豆首页 | 免费精品在线 | 午夜av在线电影 | 中文字幕第一页在线vr | 久久99久久99精品免视看婷婷 | 国产精品久久久99 | av中文字幕网 | 亚洲 欧洲av| 永久免费观看视频 | 麻豆综合网 | 欧美精品乱码久久久久久按摩 | 欧美在线视频一区二区 | 国产亚洲精品久久久久久电影 | 色吊丝在线永久观看最新版本 | 国产午夜三级一区二区三桃花影视 | 婷婷在线播放 | 国产精品久久久久免费观看 | 久久久久久久福利 | 国产99一区二区 | 日日夜夜婷婷 | 国产小视频在线免费观看 | 久久免费视频在线观看6 | 热久久视久久精品18亚洲精品 | 国产剧情一区在线 | 亚洲日本在线一区 | 国产伦理精品一区二区 | 色婷婷综合激情 | 91精品国自产在线 | 国产午夜精品福利视频 | 久久婷婷激情 | 欧美福利久久 | 中文字幕免费观看 | 手机在线中文字幕 | 国产一区二区高清 | 大型av综合网站 | 二区三区精品 | 久久精品亚洲精品国产欧美 | 欧美日韩伦理一区 | 中文字幕中文字幕在线中文字幕三区 | 一区二区av | 久久国产电影院 | 亚洲va欧美va国产va黑人 | 五月婷网 | 免费av片在线 | 午夜精品一区二区三区在线视频 | 亚洲精品国产欧美在线观看 | 免费中午字幕无吗 | 日韩中文字幕免费在线观看 | 日韩av资源在线观看 | 久久国产片 | 国产日韩在线观看一区 | 日韩精品五月天 | 亚洲aⅴ乱码精品成人区 | 亚洲精品乱码白浆高清久久久久久 | 91av在| 四虎成人精品在永久免费 | 国产小视频免费观看 | 免费在线观看av网址 | 狠狠干婷婷| 亚洲精品资源 | 一级片视频免费观看 | 日韩a欧美 | 日韩一三区| 天天色天天上天天操 | 国产精品免费在线观看视频 | a色视频 | 国产高清一区二区 | 激情五月在线视频 | 欧美一区二区在线刺激视频 | 久久久久久久久久伊人 | 精品极品在线 | 亚洲国产美女久久久久 | 日韩不卡高清视频 | 91污污| 国产精品久久久久久婷婷天堂 | 91中文字幕网 | 黄色毛片大全 | 日韩欧美视频免费看 | 激情大尺度视频 | 亚洲综合情| 精品人人人人 | 国产超碰在线观看 | 亚洲男女精品 | 成人av.com | 黄色国产精品 | 狠狠操导航 | 久久看视频 | 国产精品 日韩精品 | 国产免费人成xvideos视频 | 九七视频在线观看 | 2018好看的中文在线观看 | 日韩av三区 | 久久久久伊人 | 91精品国产乱码 | 国产理论片在线观看 | 欧美地下肉体性派对 | 国产欧美综合在线观看 | 成 人 免费 黄 色 视频 | 天天干一干 | 人人澡av| 九九精品在线观看 | 一区av在线播放 | 97人人添人澡人人爽超碰动图 | 天天爱天天射天天干天天 | 一区二区视频免费在线观看 | 天堂网中文在线 | www.久久精品视频 | 国产高清网站 | 奇米导航 | 国产高潮久久 | 92av视频 | 成年人毛片在线观看 | 美女精品在线 | 午夜精品久久久久 | 在线免费视 | 国产精品一区二区视频 | 国产美女在线免费观看 | 91夫妻自拍 | 精品国产免费人成在线观看 | 日b视频在线观看网址 | 国产成人99av超碰超爽 | 国产一区二区三区四区大秀 | 干干日日| 国产精品九九久久久久久久 | 香蕉手机在线 | 国产美女视频 | 久草免费福利在线观看 | 日韩av女优视频 | 在线看污网站 | 久久在线播放 | 黄色成人av在线 | 一级电影免费在线观看 | 香蕉视频在线免费 | 黄色三几片 | 波多野结衣在线中文字幕 | 免费在线黄色av | 玖玖视频国产 | 国产精品国产亚洲精品看不卡15 | 国产永久网站 | 色婷婷导航| 免费av网址在线观看 | 狠狠狠狠狠狠狠狠干 | 手机成人av在线 | 在线视频 91 | 中文电影网 | 91精品在线免费 | 国产精品成人一区 | 正在播放一区 | 亚洲色图色 | 国产精品第2页 | 看av在线| 波多野结衣视频在线 | 中文电影网| 懂色av一区二区在线播放 | 91干干干 | 成人久久亚洲 | 色99视频| 免费在线播放视频 | 日韩一级黄色av | 色播亚洲婷婷 | 伊人五月婷 | 亚洲精品欧美成人 | 黄色软件在线看 | 国产精品久久久久aaaa九色 | 久久99国产精品久久99 | 免费看的国产视频网站 | 特级西西人体444是什么意思 | 日韩精品一区二区在线视频 | 久久9视频 | 婷婷色吧| 国产成人精品久久久 | 美女亚洲精品 | 日韩毛片在线一区二区毛片 | 国产亚洲人成网站在线观看 | 国产成人在线播放 | 欧美乱熟臀69xxxxxx | 成人黄色在线电影 | 天天躁日日躁狠狠 | 国产99久久久国产精品免费二区 | 天天干天天拍天天操天天拍 | 特级西西444www大精品视频免费看 | 免费看精品久久片 | 国产精品一区二区三区免费看 | 日韩视频在线观看视频 | 久久高清免费观看 | 香蕉精品视频在线观看 | 91传媒在线观看 | 黄色三级网站在线观看 | 国产精品不卡 | 99在线精品免费视频九九视 | 国产又黄又猛又粗 | 日韩系列在线观看 | 极品美女被弄高潮视频网站 | 久草国产视频 | av成人在线网站 | 超碰国产人人 | 国产亚洲视频在线免费观看 | 综合在线亚洲 | av成人动漫 | 午夜久久影院 | 黄色小网站免费看 | 天天操天天色天天 | aⅴ视频在线 | 99色婷婷 | 午夜丁香视频在线观看 | 亚洲精品高清视频 | 色香网| 日韩精品久久久久 | 国产精品中文久久久久久久 | 久久艹久久 | 婷婷视频导航 | 69国产精品视频免费观看 | 99久久综合狠狠综合久久 | 美女黄色网在线播放 | 天天摸夜夜添 | 中文字幕欧美激情 | 久久黄视频 | 日本99精品| 久久精品视频在线免费观看 | 国模一二三区 | 国产精品99久久久久久大便 | 香蕉视频导航 | 激情影音先锋 | 国产精品丝袜在线 | 久操久 | 蜜臀av夜夜澡人人爽人人桃色 | 九九交易行官网 | 久久精品一区二区国产 | 国产69精品久久99的直播节目 | 亚洲综合网 | 在线免费性生活片 | 亚洲中字幕 | 亚洲精品午夜久久久久久久久久久 | 色婷婷狠 | 国产精品久久久久久久久久不蜜月 | 手机在线看片日韩 | 深爱开心激情 | 久久男人中文字幕资源站 | 久久毛片网站 | 99热这里精品 | 欧美激情第28页 | www.精选视频.com | 激情综合五月婷婷 | 人人澡人摸人人添学生av | 91免费版成人 | 亚洲国产小视频在线观看 | 国产精品久久久久av | 激情综合婷婷 | 欧美日韩国产免费视频 | 欧美一区二区在线看 | 国产馆在线播放 | 香蕉影视在线观看 | 欧美激情视频三区 | 精品亚洲免a | 天天操一操| 97超碰免费在线观看 | 99精品国产99久久久久久97 | www.天天综合 | 99精品视频免费全部在线 | 成人丁香花 | 香蕉久久久久久久 | 国产一级淫片免费看 | 亚州av免费 | 免费91在线 | 99精品视频免费在线观看 | 久久久久国产精品一区二区 | 亚洲男男gaygay无套同网址 | 国产免费影院 | 中文字幕在线免费观看视频 | 麻豆视频免费入口 | 天堂在线一区二区三区 | 中文字幕国产视频 | 亚洲精品18p | 日韩在线不卡视频 | 天天操天天舔天天干 | 日女人免费视频 | av无限看 | 久久久久这里只有精品 | 欧美日韩国产亚洲乱码字幕 | 激情文学丁香 | 91九色在线视频观看 | 96精品在线 | 久久精品视频在线 | 91久久精品一区 | 丁香花在线视频观看免费 | 精品中文字幕在线 | 国产成人一区三区 | 日韩在线观看中文字幕 | 日本精品一区二区三区在线播放视频 | 免费在线观看91 | 精品一区二区三区四区在线 | 国产一区二区在线免费视频 | 国产成人免费在线 | 亚洲综合色视频在线观看 | www.99久久.com| 不卡的av电影 | 国产精品对白一区二区三区 | 91丨九色丨国产丨porny精品 | 91精品网站 | 人人射人人射 | 色偷偷888欧美精品久久久 | 人人玩人人添人人澡97 | 天天射天天搞 | 国产探花视频在线播放 | 日韩在线观看第一页 | 久久精品一区二区三区四区 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 97人人澡人人爽人人模亚洲 | 亚洲韩国一区二区三区 | 91试看 | 天天干天天拍天天操天天拍 | 欧美精品久久久久久久久久 | 成人在线一区二区 | 精品99999 | 国产蜜臀av | 99av国产精品欲麻豆 | 天天射天天爱天天干 | 亚洲国产三级在线 | 99精品久久99久久久久 | 国产精品自产拍在线观看桃花 | 中文在线www| 欧美日在线 | 日韩三级av| 亚洲精品自拍视频在线观看 | 在线视频观看成人 | 国产伦精品一区二区三区在线 | 久草在线免 | 国产黄免费 | 色综合欧洲 | 国产黄大片在线观看 | 探花视频免费观看高清视频 | 亚洲草视频| 丁香视频五月 | av观看在线观看 | 久久精品超碰 | av超碰在线观看 | 免费黄av| 天天色天天草天天射 | 精品免费 | 日韩v在线 | 亚州精品在线视频 | av中文电影 | 日韩电影在线一区 | 九九视频网 | 成人羞羞视频在线观看免费 | 久草电影在线观看 | 亚洲精品在线视频观看 | 日本久久片 | 在线观看免费视频 | 午夜久久福利 | 在线电影中文字幕 | 欧美激情视频一区二区三区免费 | 久久久精品福利视频 | 国产精品 999 | 97精品国产91久久久久久久 | 欧美一区二区三区四区夜夜大片 | 天天爱av导航 | 中文字幕av在线不卡 | 一区二区不卡在线观看 | 国产录像在线观看 | 在线观看中文 | 国产麻豆视频在线观看 | 日本不卡一区二区三区在线观看 | 日本婷婷色 | 亚洲国产黄色片 | 久久久精品视频网站 | 在线免费观看国产黄色 | 国产品久精国精产拍 | 最近中文字幕在线中文高清版 | 日韩视频区 | 天堂资源在线观看视频 | 日本精品视频在线播放 | 四虎www| 麻豆视频免费在线 | 国产成人av一区二区三区在线观看 | 久久男人影院 | 日韩a在线观看 | 五月亚洲婷婷 | 天堂在线免费视频 | 深爱五月激情网 | 久久1电影院 | 西西444www大胆无视频 | 97操操操 | 国产99久久久欧美黑人 | 精品在线播放视频 | 免费精品国产va自在自线 | 日日夜夜干 | 国产精品 日韩 | 激情综合久久 | 久久久久久久18 | 午夜视频一区二区 | 美女免费视频观看网站 | 久久激五月天综合精品 | 亚洲精选久久 | 国产黄色一级片在线 | 国产在线观| 国产视频网站在线观看 | 99久久成人 | 日韩videos | 亚洲va欧美va人人爽 | 欧美日韩国产网站 | 久久免费电影网 | 激情综合网五月 | 亚洲午夜精品一区二区三区电影院 | 国产精品久久久久久久久大全 | 国产视频观看 | 亚洲最新av在线网站 | 麻花豆传媒mv在线观看网站 | 国产精品成人免费一区久久羞羞 | 久久亚洲福利视频 | 日韩免费福利 | 国产亚洲观看 | 国产精品6 | 国偷自产中文字幕亚洲手机在线 | 欧美日韩xxxxx | 日本护士撒尿xxxx18 | 91资源在线播放 | 欧美激情在线看 | 九九九热精品免费视频观看 | 精品久久久久久国产91 | 狠狠色丁香九九婷婷综合五月 | 色夜视频| 国产麻豆精品久久一二三 | 国产一级一片免费播放放 | 免费69视频 | 四虎国产精品免费观看视频优播 | 在线视频一二三 | 美女黄久久 | 国产又粗又猛又黄又爽的视频 | 日韩精品短视频 | 美女网站色 | 在线免费观看视频a | 福利网址在线观看 | 这里只有精品视频在线观看 | 中文字幕欧美日韩va免费视频 | 天堂va欧美va亚洲va老司机 | 97国产一区二区 | 日韩综合一区二区三区 | 蜜桃av人人夜夜澡人人爽 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | www日韩欧美| 黄色成人在线观看 | 黄污污网站 | 香蕉影视在线观看 | 国内精品久久久久影院一蜜桃 | 欧美日韩精品在线视频 | 欧美一级久久久久 | 成人免费视频播放 | 69精品久久 | 四虎永久精品在线 | 91禁在线看| 探花国产在线 | 91精品婷婷国产综合久久蝌蚪 | 91喷水 | 国产人成免费视频 | 免费在线观看日韩视频 | 黄色国产精品 | 久插视频 | 草久视频在线观看 | 久久精品国产美女 | 丝袜美腿在线视频 | 97色噜噜 | 亚洲精品理论片 | 精品一区电影 | 免费看黄色91 | 精品视频久久 | av免费播放 | 韩国av永久免费 | 国产69精品久久久久久 | 国产一级二级av | 成人精品影视 | 久久黄色小说视频 | 日韩精品第1页 | 婷香五月 | 97精品久久 | 在线免费中文字幕 | 二区视频在线观看 | 亚洲欧美婷婷六月色综合 | av电影在线免费 | 精品高清美女精品国产区 | 国产一区福利在线 | 久久久久久免费毛片精品 | av免费看av | 欧美性天天 | 黄色影院在线免费观看 | 玖玖在线资源 | 国产黄色播放 | 国产自在线 | 在线观看视频免费播放 | 久草香蕉在线 | 日韩在线首页 | 日韩激情一二三区 | 亚洲伊人成综合网 | 欧美极品少妇xbxb性爽爽视频 | 日韩精品中文字幕久久臀 | 欧美日韩国产页 | 成人黄色中文字幕 | 色综合天天爱 | 在线观看中文字幕 | 国产精品午夜在线 | 麻豆精品在线视频 | 9999国产| 亚洲无吗av | 婷婷在线网站 | 天天射狠狠干 | 99精品成人| www黄在线 | 操久久网| 亚洲特级毛片 | 丝袜美女在线观看 | 色偷偷网站视频 | 日韩网站在线免费观看 | 开心激情五月网 | av免费高清观看 | 亚洲二区精品 | 午夜精品电影一区二区在线 | 免费网站v| 久久久久亚洲精品 | 91av在线看 | 91精品亚洲影视在线观看 | 香蕉成人在线视频 | 99久久www免费 | 五月婷婷视频在线观看 | 欧美精品在线观看免费 | 欧美日韩免费观看一区二区三区 | 中文字幕在线精品 | 三级性生活视频 | 一本一道久久a久久精品蜜桃 | 99热精品在线观看 | 视频在线观看日韩 |