青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

/////////////////////////////////////////////////////////////////////////////////////

//   Iocp 頭文件

 

#pragma once

 

#include <winsock2.h>

#pragma comment( lib, "ws2_32.lib" )

 

const int OP_READ = 0;

const int OP_WRITE = 1;

const int OP_ACCEPT = 2;

 

/*

     OVERLAPPEDPLUS 結(jié)構(gòu)體設(shè)計(jì)思路

     OVERLAPPED 是一個(gè)固定的用于處理網(wǎng)絡(luò)消息事件返回值的結(jié)構(gòu)體變量

     在完成端口和重疊I/O模型里用于返回消息事件的結(jié)果

     因?yàn)樵谔幚砭W(wǎng)絡(luò)消息的時(shí)候,發(fā)送的是一個(gè)返回值的結(jié)構(gòu)體指針,只要結(jié)構(gòu)體

     的前面部分滿足系統(tǒng)的要求,在系統(tǒng)操作成功的時(shí)候也就會(huì)把這個(gè)結(jié)構(gòu)體指針

     發(fā)回給用戶,我們只要在系統(tǒng)定義的結(jié)構(gòu)體后面擴(kuò)展一些自己的東西,就可以

     很輕松的確定該消息是誰發(fā)過來的。

     不過好像完成端口在設(shè)計(jì)的時(shí)候也滿足了這樣的需求,所以在這里我只是放入

     一些與系統(tǒng)連接有關(guān)的數(shù)據(jù),用戶需要存放的數(shù)據(jù)這里就不在存放

     這里存儲(chǔ)與系統(tǒng)相關(guān)的數(shù)據(jù)有:

     socket

     OpCode 本次消息的操作類型(在完成端口的操作里面,是以消息通知系統(tǒng),

         讀數(shù)據(jù)/寫數(shù)據(jù),都是要發(fā)這樣的消息結(jié)構(gòu)體過去的,所以如果系統(tǒng)要同時(shí)

         進(jìn)行讀寫操作的話,就需要有一個(gè)變量來區(qū)分操作了)

 

     WSABUF   wbuf;                  //   讀寫緩沖區(qū)結(jié)構(gòu)體變量

     DWORD    dwBytes, dwFlags; //   一些在讀寫時(shí)用到的標(biāo)志性變量

     char buf[4096];                  //   自己的緩沖區(qū)

     上面的4個(gè)變量存放的是一些與消息相關(guān)的數(shù)據(jù),都是一些操作上用到的,

     這些東西都是固定的,具體作用需要參考一下完成端口相關(guān)函數(shù)的參數(shù)接口

*/

struct OVERLAPPEDPLUS

{

     OVERLAPPED    ol;

     SOCKET        s;

     int OpCode;

     WSABUF   wbuf;

     DWORD    dwBytes, dwFlags;

     char buf[4096];

};

 

class CIOCP

{

protected:

     HANDLE g_hwThread;     //   工作線程句柄

     DWORD m_wthreadID;

     HANDLE g_haThread;     //   連接線程句柄

     DWORD m_athreadID;

public:

     bool m_workThread;

     bool m_acceptThread;

     HANDLE m_hIocp;             //   完成端口的句柄

     SOCKET m_sSocket;

    

public:

     CIOCP(void);

     ~CIOCP(void);

     virtual void OnRead(void * p, char *buf, int len){};

     virtual void OnAccept(SOCKET socket);

     virtual void OnClose(void * p){};

     bool SetIoCompletionPort(SOCKET socket, void *p, char *buf = NULL, int len = 0);

         //   把一個(gè)socket與一個(gè)自定義的結(jié)構(gòu)體關(guān)聯(lián)到完成端口(相當(dāng)于把socket與一個(gè)結(jié)構(gòu)體變量進(jìn)行綁定),

         //   這樣當(dāng)發(fā)送上面3種網(wǎng)絡(luò)事件的時(shí)候,該結(jié)構(gòu)體變量會(huì)再傳回給程序

         //   這樣就可以區(qū)分當(dāng)前網(wǎng)絡(luò)事件是那個(gè)socket發(fā)出的

     bool Init(void);

     bool Listen(int port);

     static DWORD __stdcall WorkThread(LPVOID Param);

     static DWORD __stdcall AcceptThread(LPVOID Param);

};

 

class CIOCPClient: public CIOCP

{

protected:

     SOCKET m_socket;

public:

     bool Connect(char *ip, int port);

     void Send(char *buf, int len);

};

 

 

 

 

 

 

 

 

 

 

 

//////////////////////////////////////////////////////////////////////////////////////////

//   Iocp 實(shí)現(xiàn)文件

 

#include "StdAfx.h"

#include "iocp.h"

 

static bool bInit = false;

 

DWORD __stdcall CIOCP::WorkThread(LPVOID Param)

{

     CIOCP * pthis = (CIOCP *)Param;

 

     void * re;

     OVERLAPPED * pOverlap;

     DWORD berByte;

     while(pthis->m_workThread)

     {

         int ret;

         ret = GetQueuedCompletionStatus(pthis->m_hIocp, &berByte, (LPDWORD)&re, (LPOVERLAPPED *)&pOverlap, INFINITE);

 

         if (ret == ERROR_SUCCESS)

         {

 

         }

 

         if (berByte == 0)

         {

              //   客戶端斷開連接

              pthis->OnClose(re);

              OVERLAPPEDPLUS *olp = (OVERLAPPEDPLUS *)pOverlap;

              closesocket(olp->s);

              delete olp;        //   釋放 socket綁定的結(jié)構(gòu)體變量

              continue;

         }

 

         if (re == NULL) return 0;

 

         OVERLAPPEDPLUS *olp = (OVERLAPPEDPLUS *)pOverlap;

 

         switch(olp->OpCode)

         {

         case OP_READ:

              pthis->OnRead(re, olp->wbuf.buf, berByte);     //   調(diào)用 OnRead() 通知應(yīng)用程序,服務(wù)器收到來自客戶端的網(wǎng)絡(luò)數(shù)據(jù)

              WSARecv(olp->s, &olp->wbuf, 1, &olp->dwBytes, &olp->dwFlags, &olp->ol, NULL); //   繼續(xù)調(diào)用一個(gè)接收的 I/O 異步請(qǐng)求

              break;

         default:

              break;

         }

     }

     return 0;

}

 

DWORD __stdcall CIOCP::AcceptThread(LPVOID Param)

{

     CIOCP * pthis = (CIOCP *)Param;

     while(pthis->m_acceptThread)

     {

         SOCKET client;

         if ((client= accept(pthis->m_sSocket, NULL, NULL)) == INVALID_SOCKET)

         {

              //   錯(cuò)誤處理

         }

         pthis->OnAccept(client);    //   調(diào)用 OnAccept()通知應(yīng)用程序有新客戶端連接

        

     }

     return 1;

}

 

CIOCP::CIOCP(void)

{

}

 

CIOCP::~CIOCP(void)

{

}

 

bool CIOCP::Init(void)

{

     if (bInit)

         return true;

 

     WSADATA wsd;

     if (WSAStartup(MAKEWORD(2,2), &wsd) != 0)

         return false;

 

     bInit = true;

     return true;

}

 

bool CIOCP::Listen(int port)

{

     if (!bInit)

         if (!Init())

              return false;

 

     m_sSocket = socket(AF_INET, SOCK_STREAM, 0);

 

     if (m_sSocket == INVALID_SOCKET)

         return false;

 

     //SOCKADDR_IN addr;

     sockaddr_in addr;

     addr.sin_family = AF_INET;

     addr.sin_port = htons(port);

     addr.sin_addr.S_un.S_addr = htonl(INADDR_ANY);

     //addr.sin_addr.S_un.S_addr = inet_addr(ip);

 

     if (bind(m_sSocket, (struct sockaddr *)&addr, sizeof(addr)) == SOCKET_ERROR)

         return false;

 

     if (listen(m_sSocket, 10) == SOCKET_ERROR)

         return false;

 

     if ((m_hIocp = CreateIoCompletionPort(INVALID_HANDLE_VALUE, NULL, NULL, 0)) == NULL)     //   創(chuàng)建完成端口的句柄

         return false;

 

     this->m_acceptThread = true;

     g_haThread = CreateThread(NULL, 0, AcceptThread, (LPVOID)this, 0, &m_athreadID);    //   創(chuàng)建連接線程,用來接收客戶端的連接

 

     this->m_workThread = true;

     g_hwThread = CreateThread(NULL, 0, WorkThread, (LPVOID)this, 0, &m_wthreadID); //   創(chuàng)建工作線程,用來處理完成端口消息的

     return true;

}

 

bool CIOCP::SetIoCompletionPort(SOCKET socket, void *p, char *buf, int len)

{

     if (CreateIoCompletionPort((HANDLE)socket, m_hIocp, (ULONG_PTR)p, 0) == NULL)

         return false;

 

     OVERLAPPEDPLUS *olp = new OVERLAPPEDPLUS;

     memset(olp, 0, sizeof(OVERLAPPEDPLUS));

     olp->s = socket;

     if (buf)

     {

         //   這里可以使用用戶自定義的緩沖區(qū)地址,如果用戶不想設(shè)置,也可以采用默認(rèn)分配的緩沖區(qū)

         olp->wbuf.buf = buf;

         olp->wbuf.len = len;

     }

     else

     {

         olp->wbuf.buf = olp->buf;

         olp->wbuf.len = 4096;

     }

     olp->OpCode = OP_READ;

     int ret = WSARecv(olp->s, &olp->wbuf, 1, &olp->dwBytes, &olp->dwFlags, &olp->ol, NULL);

     if (ret == SOCKET_ERROR)

         if (WSAGetLastError() != ERROR_IO_PENDING)

              return false;

     return true;

}

 

void CIOCP::OnAccept(SOCKET socket)

{

     this->SetIoCompletionPort(socket, NULL);

}

 

//===================================================================================

bool CIOCPClient::Connect(char *ip, int port)

{

         //   連接服務(wù)器

     if (!bInit)

         if (!Init())

              return false;

 

     //   初始化連接socket

     m_socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);

     if (m_socket == SOCKET_ERROR)

     {

//       printf("cocket Create fail");

         return false;

     }

 

     // 填寫服務(wù)器地址信息

     // 端口為1982

     // IP地址為INADDR_ANY,注意使用htonlIP地址轉(zhuǎn)換為網(wǎng)絡(luò)格式ServerAddr.sin_family = AF_INET;

     sockaddr_in ClientAddr;

     ClientAddr.sin_family = AF_INET;

     ClientAddr.sin_port = htons(port);   

     ClientAddr.sin_addr.s_addr = inet_addr(ip);

 

     // 綁定監(jiān)聽端口

     bind(m_socket, (SOCKADDR *)&ClientAddr, sizeof(ClientAddr));

 

     if (connect(m_socket, (SOCKADDR *)&ClientAddr, sizeof(ClientAddr)) == SOCKET_ERROR)

     {

         return false;

     }

    

     if ((m_hIocp = CreateIoCompletionPort(INVALID_HANDLE_VALUE, NULL, NULL, 0)) == NULL)     //   創(chuàng)建完成端口的句柄

         return false;

 

     this->m_workThread = true;

     g_hwThread = CreateThread(NULL, 0, WorkThread, (LPVOID)this, 0, &m_wthreadID); //   創(chuàng)建工作線程,用來處理完成端口消息的

 

     this->SetIoCompletionPort(m_socket, &m_socket);    //   設(shè)置完成端口監(jiān)聽的socket

     return true;

}

 

void CIOCPClient::Send(char *buf, int len)

{

     send(m_socket, buf, len, 0);

}

 

 

///////////////////////////////////////////////////////////////////////////////////

// IOCPclient 應(yīng)用代碼

 

#include "stdafx.h"

#include "IOCP.h"

#include "TClientSocket.h"

class Iocp :public CIOCPClient

{

      void OnRead(void * p, char *buf, int len)

      {

          printf(buf);

          Sleep(1000);

          this->Send(buf, len);

      }

};

 

int _tmain(int argc, _TCHAR* argv[])

{

     Iocp iocp;

     iocp.Init();

     iocp.Connect("127.0.0.1", 4311);

     iocp.Send("test\0", 5);

    

     gets(new char[1000]);

     return 0;

}

Feedback

# re: 【轉(zhuǎn)】完成端口的一個(gè)簡(jiǎn)單封裝類   回復(fù)  更多評(píng)論   

2011-03-11 19:45 by 小不點(diǎn)
http://blog.csdn.net/guestcode/category/569314.aspx
IOCP 服務(wù)器學(xué)習(xí)。

# re: 【轉(zhuǎn)】完成端口的一個(gè)簡(jiǎn)單封裝類   回復(fù)  更多評(píng)論   

2011-03-11 20:03 by 小不點(diǎn)
http://www.hellocpp.net/Articles/Article/436.aspx

# re: 【轉(zhuǎn)】完成端口的一個(gè)簡(jiǎn)單封裝類   回復(fù)  更多評(píng)論   

2011-03-11 22:00 by 小不點(diǎn)
Single-Linked-List
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲精品自在久久| 亚洲在线播放| 欧美成人性生活| 久久综合伊人77777麻豆| 狠狠色狠狠色综合人人| 欧美jizz19hd性欧美| 欧美11—12娇小xxxx| av成人黄色| 亚洲欧美在线网| 亚洲国产精品一区二区尤物区| 你懂的国产精品| 欧美日韩国产高清视频| 性欧美大战久久久久久久免费观看 | 欧美日韩午夜精品| 欧美在线一级va免费观看| 久久久久久久高潮| 一本久久a久久免费精品不卡| 亚洲私人影院在线观看| 在线观看av不卡| 亚洲天堂成人在线视频| 好吊色欧美一区二区三区四区| 亚洲国产高清在线观看视频| 欧美色综合天天久久综合精品| 久久天天狠狠| 国产精品99一区二区| 久久夜色精品国产| 欧美午夜片在线免费观看| 美女91精品| 国产精品美女在线观看| 最新国产成人av网站网址麻豆| 国产精品揄拍500视频| 欧美成人资源| 国产一区二区三区四区老人| 亚洲毛片在线看| 亚洲国产裸拍裸体视频在线观看乱了中文 | 伊人伊人伊人久久| 宅男66日本亚洲欧美视频| 亚洲人成在线观看一区二区| 亚洲男人影院| 亚洲一本大道在线| 男同欧美伦乱| 免费久久精品视频| 国产欧美一区二区精品性色| 亚洲免费电影在线| 亚洲精品国产精品国自产观看 | 亚洲欧洲美洲综合色网| 国产主播在线一区| 亚洲一区在线免费观看| 一本久久综合亚洲鲁鲁五月天| 久久亚洲欧美国产精品乐播| 久久亚洲欧美| 亚洲一区二区三区在线| 亚洲欧美视频在线| 亚洲一区精品电影| 欧美日本一道本在线视频| 欧美大片一区二区| 在线日韩欧美| 美女视频黄a大片欧美| 老司机成人网| 狠狠综合久久| 久久久欧美精品sm网站| 久久裸体视频| 黄色成人片子| 免费不卡中文字幕视频| 欧美大尺度在线观看| 亚洲第一页自拍| 久久亚洲一区二区| 欧美激情aⅴ一区二区三区| 亚洲第一在线综合在线| 免费亚洲婷婷| 亚洲免费av电影| 亚洲欧美在线免费观看| 国产欧美丝祙| 久久久青草青青国产亚洲免观| 欧美成人a∨高清免费观看| 亚洲大片在线观看| 欧美激情精品久久久久久免费印度 | 午夜精品久久久久久久蜜桃app | 亚洲精品视频在线播放| 欧美日韩国产免费| 99热这里只有精品8| 亚洲欧美偷拍卡通变态| 国内精品模特av私拍在线观看| 久久精品国产久精国产思思| 欧美成人r级一区二区三区| 99精品视频免费| 国产人成精品一区二区三| 久久精品首页| 一本大道久久a久久精品综合| 亚洲欧美国产视频| 在线播放国产一区中文字幕剧情欧美 | 免费成人av资源网| 亚洲卡通欧美制服中文| 亚洲欧美日本日韩| 悠悠资源网久久精品| 欧美日韩综合视频| 久久精品免费播放| 日韩视频在线观看国产| 久久视频一区| 亚洲综合色自拍一区| 激情成人av| 国产精品二区二区三区| 久久久精品五月天| 亚洲视频日本| 亚洲第一网站| 久久精品电影| 亚洲丝袜av一区| 亚洲高清资源| 激情欧美国产欧美| 国产精品av免费在线观看 | 99国内精品久久| 麻豆精品传媒视频| 久久人人爽国产| 亚洲一区二区综合| 亚洲国产欧美一区| 久久精品动漫| 性欧美8khd高清极品| 一区二区欧美日韩| 亚洲日本va午夜在线电影| 一区二区三区在线看| 国产精品午夜在线| 欧美日韩高清一区| 免费欧美日韩| 久久精品一区二区三区不卡| 亚洲午夜久久久久久久久电影网| 亚洲大胆美女视频| 久久综合电影一区| 久久精品av麻豆的观看方式| 午夜免费久久久久| 午夜精品美女久久久久av福利| 亚洲天堂久久| 亚洲午夜精品在线| 99精品国产99久久久久久福利| 伊人久久综合| 亚洲成在线观看| 亚洲国产欧美日韩精品| 影音先锋日韩资源| 一区二区三区在线观看欧美 | 国产精品五区| 国产精品你懂得| 国产精品无码专区在线观看| 国产精品毛片一区二区三区 | 欧美成人一品| 欧美精品日韩www.p站| 欧美—级在线免费片| 欧美黄色一级视频| 欧美日韩高清区| 国产精品久久久久久久久久免费看| 欧美日韩一区二区三区| 欧美视频不卡| 国产深夜精品福利| 在线免费观看日本欧美| 一区二区视频免费在线观看| 亚洲国产电影| 一区二区三区国产精华| 午夜欧美不卡精品aaaaa| 久久av在线看| 欧美刺激午夜性久久久久久久| 欧美激情久久久久| 99综合在线| 欧美一区二区三区四区在线观看地址 | 欧美伊人精品成人久久综合97| 久久精品视频免费观看| 欧美高清不卡| 国产精品久线观看视频| 激情亚洲网站| 99视频一区二区三区| 欧美一区二区三区在线视频 | 亚洲高清在线精品| 一区二区三区欧美成人| 欧美在线观看一二区| 欧美~级网站不卡| 国产精品视频久久一区| 18成人免费观看视频| 一区二区三区四区蜜桃| 久久久久网址| 亚洲精品一区二区在线| 欧美一区二区三区四区高清| 男人的天堂亚洲| 国产亚洲亚洲| 亚洲视频在线播放| 噜噜噜在线观看免费视频日韩| 99精品免费网| 国产精品夜夜夜一区二区三区尤| 亚洲欧美美女| 欧美韩国日本一区| 亚洲欧美bt| 欧美日韩美女| 亚洲黄页一区| 久久久美女艺术照精彩视频福利播放| 亚洲成人在线视频播放 | 亚洲美洲欧洲综合国产一区| 欧美综合第一页| 国产精品第一页第二页第三页| 亚洲国产精品v| 久久久久久久波多野高潮日日| 日韩视频在线一区| 欧美成人精品1314www| 国产一区二区三区视频在线观看| 在线视频精品一区|