winsock IO 模型的笔记
来源:互联网 发布:淘宝买灯具可靠吗 编辑:程序博客网 时间:2024/06/15 06:03
//调用Windows Sockets DLL
WSADATA wsaData;
WSAStartup(MAKEWORD(2,2),&wsaData);
... ...
//结束Winsock库,卸载这个库并释放资源
int WSACleanup (void);
... ...
//套接字,就是一个指向传输提供者的句柄,是一个独立的类型—S O C K E T.由两个函数建立
SOCKET socket (
int af,
int type,
int protocol
);
... ...
SOCKET WSASocket(
int af,
int type,
int protocol,
LPWSAPROTOCOL_INFO lpProtocolInfo,
GROUP g,
DWORD dwFlags);
... ...
//尝试重载enum的++运算符
http://topic.csdn.net/t/20060621/13/4834473.html
//20090531重叠IO事件通知代码整理
WSADATA wsaData;
if (WSAStartup(MAKEWORD(2,2),&wsaData)) //调用Windows Sockets DLL
{
m_GRAPH1STATE=_T("无法创建服务器socket");
UpdateData(FALSE);
WSACleanup();
return;
}
unsigned long ul=1;
//int nRet;
//ServerSocket[0]=socket(PF_INET,SOCK_STREAM,0);
ServerSocket[0]=WSASocket(AF_INET, SOCK_STREAM, IPPROTO_IP, NULL, 0, WSA_FLAG_OVERLAPPED);
//nRet=ioctlsocket(ServerSocket[0],FIONBIO,(unsigned long *)&ul);
//if (nRet==SOCKET_ERROR)
//{
// return;
//}
sockStruct[0].sin_family=AF_INET; //使用TCP/IP协议
sockStruct[0].sin_port = htons(8001);
sockStruct[0].sin_addr.S_un.S_addr = inet_addr("192.168.1.7");
if(connect(ServerSocket[0],(LPSOCKADDR)&sockStruct[0],sizeof(sockStruct[0])) == SOCKET_ERROR)
{
int m_errorcode=WSAGetLastError();
//return;
}
WSAOVERLAPPED AcceptOverlapped;
WSAEVENT m_Event;
WSABUF DataBuf[64];
DWORD dwEventTotal = 0,
dwRecvBytes = 0,
Flags = 0;
int nSockIndex = 0; // socket数组的编号
BOOL bOverlapped = FALSE; // 是否处理重叠请求
Flags = 0;
m_Event = WSACreateEvent();
ZeroMemory(&AcceptOverlapped,sizeof(WSAOVERLAPPED));
char buffer[4096];
ZeroMemory(buffer,4096);
AcceptOverlapped.hEvent = m_Event; // 关联事件
DataBuf[0].len = 4096;
DataBuf[0].buf = buffer;
// 投递第一个WSARecv请求,以便开始在套接字上接受数据
if(WSARecv(ServerSocket[0] ,&DataBuf[0],1,&dwRecvBytes,&Flags,
& AcceptOverlapped ,NULL) == SOCKET_ERROR)
{
int mError=WSAGetLastError();
if(WSAGetLastError() != WSA_IO_PENDING)
{
// 返回WSA_IO_PENDING是正常情况,表示IO操作正在进行,不能立即完成
// 如果不是WSA_IO_PENDING错误,就表示操作失败了
AfxMessageBox("错误:第一次投递Recv操作失败!!此套接字将被关闭!");
closesocket(ServerSocket[0]);
ServerSocket[0] = INVALID_SOCKET;
WSACloseEvent(m_Event);
}
}
WSAOVERLAPPED AcceptOverlapped;
WSAEVENT m_Event;
WSABUF DataBuf[64];
DWORD dwEventTotal = 0,
dwRecvBytes = 0,
Flags = 0;
int nSockIndex = 0; // socket数组的编号
BOOL bOverlapped = FALSE; // 是否处理重叠请求
Flags = 0;
m_Event = WSACreateEvent();
ZeroMemory(&AcceptOverlapped,sizeof(WSAOVERLAPPED));
char buffer[4096];
ZeroMemory(buffer,4096);
AcceptOverlapped.hEvent = m_Event; // 关联事件
DataBuf[0].len = 4096;
DataBuf[0].buf = buffer;
// 投递第一个WSARecv请求,以便开始在套接字上接受数据
if(WSARecv(ServerSocket[0] ,&DataBuf[0],1,&dwRecvBytes,&Flags,
& AcceptOverlapped ,NULL) == SOCKET_ERROR)
{
int mError=WSAGetLastError();
if(WSAGetLastError() != WSA_IO_PENDING)
{
// 返回WSA_IO_PENDING是正常情况,表示IO操作正在进行,不能立即完成
// 如果不是WSA_IO_PENDING错误,就表示操作失败了
AfxMessageBox("错误:第一次投递Recv操作失败!!此套接字将被关闭!");
closesocket(ServerSocket[0]);
ServerSocket[0] = INVALID_SOCKET;
WSACloseEvent(m_Event);
}
}
// Process overlapped receives on the socket
while(TRUE)
{
DWORD Index;
// Step 5:
// Wait for the overlapped I/O call to complete
Index = WSAWaitForMultipleEvents(1,
&m_Event, FALSE, WSA_INFINITE, FALSE);
// Index should be 0 because we
// have only one event handle in EventArray
// Step 6:
// Reset the signaled event
WSAResetEvent(m_Event);
// Step 7:
// Determine the status of the overlapped
// request
unsigned long BytesTransferred=0;
WSAGetOverlappedResult(ServerSocket[0],
&AcceptOverlapped, &BytesTransferred,
FALSE, &Flags);
// First check to see whether the peer has closed
// the connection, and if so, close the
// socket
if (BytesTransferred == 0)
{
printf("Closing socket %d/n", ServerSocket[0]);
closesocket(ServerSocket[0]);
WSACloseEvent(m_Event);
return;
}
// Do something with the received data
// DataBuf contains the received data
//...
// Step 8:
// Post another WSARecv() request on the socket
Flags = 0;
ZeroMemory(&AcceptOverlapped,
sizeof(WSAOVERLAPPED));
AcceptOverlapped.hEvent = m_Event;
DataBuf[0].len = 4096;
DataBuf[0].buf = buffer;
if (WSARecv(ServerSocket[0] ,&DataBuf[0],1,&dwRecvBytes,&Flags,
& AcceptOverlapped ,NULL) == SOCKET_ERROR)
{
if (WSAGetLastError() != WSA_IO_PENDING)
{
// Unexpected error
}
}
}
- winsock IO 模型的笔记
- winsock IO模型1
- winsock IO模型2
- winsock重叠IO模型
- winsock IO模型 WSAEventSelect
- winsock IO模型WSAAsynSelect
- WinSock IO模型 实例
- WinSock IO 模型
- WinSock IO模型
- WinSock IO模型---重叠模型
- winsock IO模型 select模型
- winsock IO模型 select模型
- WinSock---WSAAsyncSelect IO模型和select模型的比较
- WinSock IO 模型形象说明
- winSock IO 模型形象说明
- WinSock重叠IO模型一
- Winsock异步IO----select模型
- winsock IO模型 完成端口
- Css+Div布局学习(一)—Div布局基础
- Css+Div布局学习(二)—清理Clear
- Css+Div布局学习(三)—定位Position
- Css+Div布局学习(四)—关于hack
- CSS_淘宝页面上一些圆角的做法
- winsock IO 模型的笔记
- 解决There is no READABLE property named 'SID'问题
- 工作组模式下设置文件共享_我的技术论文_IT网络
- Css+Div布局学习(五)—overflow
- TCP/IP协议:TCP与UDP的理解
- JavaScript学习笔记2
- 在虚拟中搭建SQL server2005的注意事项
- DedeCMSV53任意变量覆盖漏洞
- SP解锁、加锁全攻略