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

【轉】完成端口的一個簡單封裝類

Posted on 2008-01-18 21:29 MiweiDev 閱讀(1193) 評論(3)  編輯 收藏 引用 所屬分類: 網絡編程

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

//   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 結構體設計思路

     OVERLAPPED 是一個固定的用于處理網絡消息事件返回值的結構體變量

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

     因為在處理網絡消息的時候,發送的是一個返回值的結構體指針,只要結構體

     的前面部分滿足系統的要求,在系統操作成功的時候也就會把這個結構體指針

     發回給用戶,我們只要在系統定義的結構體后面擴展一些自己的東西,就可以

     很輕松的確定該消息是誰發過來的。

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

     一些與系統連接有關的數據,用戶需要存放的數據這里就不在存放

     這里存儲與系統相關的數據有:

     socket

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

         讀數據/寫數據,都是要發這樣的消息結構體過去的,所以如果系統要同時

         進行讀寫操作的話,就需要有一個變量來區分操作了)

 

     WSABUF   wbuf;                  //   讀寫緩沖區結構體變量

     DWORD    dwBytes, dwFlags; //   一些在讀寫時用到的標志性變量

     char buf[4096];                  //   自己的緩沖區

     上面的4個變量存放的是一些與消息相關的數據,都是一些操作上用到的,

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

*/

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);

         //   把一個socket與一個自定義的結構體關聯到完成端口(相當于把socket與一個結構體變量進行綁定),

         //   這樣當發送上面3種網絡事件的時候,該結構體變量會再傳回給程序

         //   這樣就可以區分當前網絡事件是那個socket發出的

     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 實現文件

 

#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綁定的結構體變量

              continue;

         }

 

         if (re == NULL) return 0;

 

         OVERLAPPEDPLUS *olp = (OVERLAPPEDPLUS *)pOverlap;

 

         switch(olp->OpCode)

         {

         case OP_READ:

              pthis->OnRead(re, olp->wbuf.buf, berByte);     //   調用 OnRead() 通知應用程序,服務器收到來自客戶端的網絡數據

              WSARecv(olp->s, &olp->wbuf, 1, &olp->dwBytes, &olp->dwFlags, &olp->ol, NULL); //   繼續調用一個接收的 I/O 異步請求

              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)

         {

              //   錯誤處理

         }

         pthis->OnAccept(client);    //   調用 OnAccept()通知應用程序有新客戶端連接

        

     }

     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)     //   創建完成端口的句柄

         return false;

 

     this->m_acceptThread = true;

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

 

     this->m_workThread = true;

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

     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)

     {

         //   這里可以使用用戶自定義的緩沖區地址,如果用戶不想設置,也可以采用默認分配的緩沖區

         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)

{

         //   連接服務器

     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;

     }

 

     // 填寫服務器地址信息

     // 端口為1982

     // IP地址為INADDR_ANY,注意使用htonlIP地址轉換為網絡格式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);

 

     // 綁定監聽端口

     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)     //   創建完成端口的句柄

         return false;

 

     this->m_workThread = true;

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

 

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

     return true;

}

 

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

{

     send(m_socket, buf, len, 0);

}

 

 

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

// IOCPclient 應用代碼

 

#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: 【轉】完成端口的一個簡單封裝類   回復  更多評論   

2011-03-11 19:45 by 小不點
http://blog.csdn.net/guestcode/category/569314.aspx
IOCP 服務器學習。

# re: 【轉】完成端口的一個簡單封裝類   回復  更多評論   

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

# re: 【轉】完成端口的一個簡單封裝類   回復  更多評論   

2011-03-11 22:00 by 小不點
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>
            久久国产加勒比精品无码| 亚洲精品中文字幕在线观看| 欧美在线播放视频| 老司机午夜免费精品视频 | 欧美涩涩网站| 亚洲一区影音先锋| 久久精品123| 亚洲黄色av| 欧美午夜一区| 久久精品人人爽| 亚洲欧洲另类| 性欧美xxxx视频在线观看| 黄色欧美日韩| 欧美欧美午夜aⅴ在线观看| 亚洲综合导航| 欧美激情片在线观看| 亚洲欧美成人在线| 在线观看中文字幕亚洲| 欧美色欧美亚洲另类二区| 午夜日本精品| 亚洲欧洲日韩综合二区| 欧美专区中文字幕| 日韩午夜在线视频| 国产亚洲一二三区| 欧美日韩精品一区二区在线播放 | 国产亚洲成精品久久| 你懂的国产精品| 亚洲女同同性videoxma| 亚洲高清二区| 久久精品日产第一区二区| 一区二区高清视频在线观看| 国产在线精品成人一区二区三区| 欧美日韩的一区二区| 久久精品视频一| 亚洲视频你懂的| 亚洲国产一区二区精品专区| 久久天天躁狠狠躁夜夜爽蜜月| 一本色道久久综合亚洲精品婷婷| 国内精品久久久久久久97牛牛| 欧美视频在线观看视频极品 | 国产精品一二三| 欧美精品电影在线| 久久综合九色综合欧美就去吻| 亚洲一区二区黄| 99精品国产热久久91蜜凸| 欧美粗暴jizz性欧美20| 久久久av毛片精品| 欧美在线亚洲| 亚洲欧美在线磁力| 亚洲午夜国产一区99re久久| 1024成人网色www| 国产亚洲视频在线观看| 国产精品一级二级三级| 欧美日韩一区二| 欧美日本不卡| 欧美精品在欧美一区二区少妇| 美女黄网久久| 久久婷婷综合激情| 久久频这里精品99香蕉| 欧美在线不卡| 欧美一区二区三区在线观看视频| 亚洲视频免费看| 亚洲午夜在线| 亚洲午夜一区| 亚洲影视综合| 午夜在线一区| 欧美一区二区成人6969| 欧美一区成人| 久久狠狠一本精品综合网| 欧美在线关看| 久久九九久精品国产免费直播| 欧美中文在线观看| 久久精品亚洲| 免费欧美日韩| 欧美精品福利| 国产精品成人v| 国产毛片精品视频| 韩国自拍一区| 91久久夜色精品国产网站| 亚洲美女在线视频| 一区二区三区回区在观看免费视频| 一本色道久久精品| 亚洲欧美日韩国产成人精品影院| 性欧美1819sex性高清| 久久精品99无色码中文字幕 | 欧美好骚综合网| 欧美精品九九| 国产精品久久久久久久久动漫| 国产精品网红福利| 狠狠狠色丁香婷婷综合激情| 亚洲国产另类久久精品| 亚洲老板91色精品久久| 亚洲欧美经典视频| 久久久人人人| 最新成人在线| 亚洲欧美激情一区二区| 久久婷婷国产综合精品青草| 欧美精品在线极品| 国产精品婷婷午夜在线观看| 精品盗摄一区二区三区| 夜夜爽99久久国产综合精品女不卡| 亚洲一区精品视频| 久热国产精品| 亚洲美女免费视频| 欧美中文字幕视频在线观看| 免费日韩一区二区| 国产精品视频精品| 亚洲国产日韩欧美综合久久| 亚洲一区二区在线看| 另类国产ts人妖高潮视频| 亚洲国产高清在线| 欧美亚洲自偷自偷| 欧美日本国产一区| 精品动漫3d一区二区三区免费版| 一本色道久久综合亚洲精品按摩| 欧美资源在线| 日韩午夜在线观看视频| 久久久91精品| 国产精品久久久久久久免费软件 | 欧美激情一区二区三区| 国产视频精品xxxx| 一本大道久久精品懂色aⅴ| 久久久久久亚洲精品不卡4k岛国| 91久久亚洲| 久久久午夜电影| 国产精品入口夜色视频大尺度| 亚洲人成网在线播放| 久久精品免费| 一区二区三区 在线观看视| 久久蜜桃av一区精品变态类天堂| 国产精品久久夜| 一区二区三区日韩精品| 欧美成人一区二区三区片免费| 午夜亚洲性色福利视频| 欧美精品一区二区在线观看| 在线精品视频一区二区| 欧美在线免费一级片| 99综合精品| 欧美精品一区二区三区久久久竹菊| 国外成人在线视频网站| 亚洲中午字幕| 亚洲精品字幕| 欧美精品成人一区二区在线观看| 亚洲第一精品久久忘忧草社区| 久久国产黑丝| 亚洲欧美中日韩| 国产精品毛片在线看| 亚洲在线观看免费| 日韩一级黄色大片| 欧美日本二区| 一本大道久久a久久精二百| 欧美黄色影院| 欧美aaa级| 亚洲精品在线观看免费| 亚洲高清不卡在线观看| 欧美成人亚洲成人| 91久久久国产精品| 亚洲国产成人精品女人久久久| 久久久夜精品| 亚洲国产欧美一区二区三区久久 | 亚洲一区二区在线看| 欧美视频在线一区| 亚洲视频欧洲视频| 9久re热视频在线精品| 欧美日韩日本国产亚洲在线| 一区二区三区 在线观看视| 亚洲精品免费一二三区| 欧美区在线播放| 亚洲图片你懂的| 亚洲制服av| 国产一区二区三区久久| 久久综合一区二区三区| 久久影视三级福利片| 亚洲人体偷拍| 日韩视频―中文字幕| 欧美网站在线| 久久不射2019中文字幕| 久久久精彩视频| 亚洲伦伦在线| 这里只有精品视频| 国产欧美精品一区二区三区介绍| 久久精品一区四区| 欧美xx69| 亚洲免费网站| 欧美在线观看天堂一区二区三区| 激情久久婷婷| 亚洲欧洲精品一区二区三区| 国产精品扒开腿爽爽爽视频| 久久九九99| 欧美国产日本在线| 性8sex亚洲区入口| 久久中文久久字幕| 亚洲一区二区三区精品视频 | 久热精品在线| 中文亚洲欧美| 久久精品成人一区二区三区| 99热在线精品观看| 欧美一区在线看| 99re国产精品| 久久成人精品无人区|