热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

winsockIO模型的笔记

调用WindowsSocketsDLLWSADATAwsaData;WSAStartup(MAKEWORD(2,2),&wsaData);

//调用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
}
}
}


推荐阅读
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • 深入理解Java虚拟机的并发编程与性能优化
    本文主要介绍了Java内存模型与线程的相关概念,探讨了并发编程在服务端应用中的重要性。同时,介绍了Java语言和虚拟机提供的工具,帮助开发人员处理并发方面的问题,提高程序的并发能力和性能优化。文章指出,充分利用计算机处理器的能力和协调线程之间的并发操作是提高服务端程序性能的关键。 ... [详细]
  • 【重识云原生】第四章云网络4.8.3.2节——Open vSwitch工作原理详解
    2OpenvSwitch架构2.1OVS整体架构ovs-vswitchd:守护程序,实现交换功能,和Linux内核兼容模块一起,实现基于流的交换flow-basedswitchin ... [详细]
  • 流数据流和IO流的使用及应用
    本文介绍了流数据流和IO流的基本概念和用法,包括输入流、输出流、字节流、字符流、缓冲区等。同时还介绍了异常处理和常用的流类,如FileReader、FileWriter、FileInputStream、FileOutputStream、OutputStreamWriter、InputStreamReader、BufferedReader、BufferedWriter等。此外,还介绍了系统流和标准流的使用。 ... [详细]
  • STM32 IO口模拟串口通讯
    转自:http:ziye334.blog.163.comblogstatic224306191201452833850647前阵子,调项目时需要用到低波 ... [详细]
  • 该楼层疑似违规已被系统折叠隐藏此楼查看此楼*madebyebhrz*#include#include#include#include#include#include#include ... [详细]
author-avatar
旧日旧面
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有