1、select 模型
int select(
int nfds, //忽略,兼容Berkeley套接字
fd_set* readfds, //可读套接字集合
fd_set* writefds, //可写套接字集合
fd_set* exceptfds, //指向套接字集合,检查错误
const struct timeval* timeout //超时时间,NULL为无限等待 typedef struct fd_set {
u_int fd_count; //数组大小
SOCKET fd_array[FD_SETSIZE]; //socket数组
}
预定义的4个操作fd_set的常用宏:
FD_ZERO(*set) 初始化set为空,清空集合
FD_CLR(s,*set) 从set移除s
FD_ISSET(s,*set)检查s是否在set中,true-存在
FD_SET(s,*set) 添加s到set中
评价:
单线程可以处理多个socket,但是需要不断进行对select返回的结果进行检查,性能不高
2、WSAAsyncSelect 模型
异步Windows消息通知模型
非阻塞同步模型,先产生windows消息,然后进行操作,操作不完成不返回
int WSAAsyncselect(
SOCKET s, //socket句柄
HWND hWnd, //指定接受消息的窗口句柄
u_int wMsg, //指定网络事件来到时接受到的消息ID
long lEvent //指定哪些网络事件需要通知
); lEvent可以取以下值的组合:
FD_READ 缓冲区有数据,可读
FD_WRITE 缓冲区变空,可写
FD_ACCEPT 有连接接入
FD_CONNECT 连接完成
FD_CLOSE socket连接关闭
LRESULT CALLBACK WindowProc(HWND hWnd,WPARAM wParam,LPARAM lParam);
wParam - socket 句柄
lParam - 高位错误代码,低位网络事件码;出错代码为0时,继续检查低位,确定网络事件
操作预定义:
#define WSAGETSELECTERROR(lParam) HIWORD(lParam) //高位错误码
#define WSAGETSELECTEVENT(lParam) LOWORD(lParam) //低位通知码
评价: 也支持多个socket同时处理,只要调用WSAAsyncSelect时设置同个窗口句柄即可,但此方式整体性能不高
3、WSAEventSelect 模型
异步事件通知I/O模型,依靠事件对象句柄通知
非阻塞同步模型,先响应事件,然后进行操作,操作不完成不返回
int WSAEventSelect(
SOCKET s, //socket句柄
WSAEVENT hEventObject, //事件对象句柄
long lNetworkEvents //指定需要通知的网络事件
); WSAEVENT WSACreateEvent(void); //创建手工重置的事件对象句柄
DWORD WSAWaitForMultipleEvents(
DWORD cEvents, //下面事件对象句柄数量
const WSAEVENT* lphEvents, //事件对象句柄数组
BOOL fWaitAll, //是否等待所有事件变为受信状态
DWORD dwTimeout, //指定等待时间,WSA_INFINITE-无穷大
BOOL fAlertable //使用WSAEventSelect时可以忽略,设为false 最多支持WSA_MAXIMUM_WAIT_EVENTS个事件对象,64个事件对象的限制,
多个事件受信时,WSAWaitForMultipleEvents返回最前一个的索引,
为了保持每个事件都得到处理,返回后要再对每个事件调用WSAWaitForMultipleEvents函数,测试状态.
一旦事件对象受信,调用WSAEnumNetworkEvents查看发生的网路事件
int WSAEnumNetworkEvents(
SOCKET s, //socket句柄
WSAEVENT hEventObject, //对应的事件对象句柄.如果提供了,则会重置该事件对象状态
LPWSANETWORKEVENTS lpNetworkEvents //指向结构的指针,函数返回的数据 typedef struct _WSANETWORKEVENTS{
long lNetworkEvent; //发生的网络事件,FD_READ等
int iErrorCode[FD_MAX_EVENTS]; //错误代码,索引对应FD_READ,FD_ACCEPT 等收到64个socket的限制,需要工作线程在WSAWaitForMultipleEvents处等待
大量socket的情况需要使用线程池
4、重叠(Overlapped)I/O 模型
基于异步的多个socket管理模型,和前几个相比有更好的系统性能
非阻塞异步模型,先进行操作,立刻返回,而后根据事件判断操作是否完成
评价:
在大量异步socket系统中,使用此模型为佳
参考文献
windows网路与通讯程序设计(windows套接字I/O模型)
分享到:
相关推荐
阻塞和非阻塞Socket Socket 编程中有两种方式:阻塞(Blocking)和非阻塞(Non-Blocking)。阻塞 Socket 指的是在执行某个操作时,程序将等待该操作完成,而非阻塞 Socket 则可以继续执行其他操作,不会被阻塞。 ...
本文档将详细介绍如何使用C++ Winsock库来开发TCP非阻塞服务器。通过本篇内容的学习,您将了解到设置socket函数为非阻塞模式的方法,并且能够深入了解阻塞与非阻塞模式在socket编程中的应用。此外,我们还将探讨...
Java TCP/IP Socket编程是Java网络通信的核心技术,广泛应用于服务器端和客户端之间的数据传输。这本书的第二版深入探讨了如何使用Java实现TCP/IP协议栈的socket接口,为开发者提供了全面的理论知识和实践指导。 ...
`Java+TCPIP+Socket编程(中文版).pdf`这个文件很可能包含了详细的教程和示例代码,可以帮助深入理解Java Socket编程的各种细节,包括如何设置套接字选项、处理多线程并发连接、使用NIO(非阻塞I/O)优化性能等高级...
总的来说,“Java TCP-IP Socket编程-卡尔弗特.pdf”这份资料应该会详细讲解以上内容,并可能涵盖更多高级主题,如NIO(非阻塞I/O)、Socket选项设置、网络编程的最佳实践等。通过学习这份资料,开发者将能够熟练...
Java TCP/IP Socket编程是网络通信领域中的核心技术,尤其在Java平台中,Socket是实现客户端与服务器之间通信的基础。原书第二版深入浅出地讲解了Java Socket编程的各个方面,为开发者提供了全面的学习资源。以下是...
书中提供了多个实用的案例,如简单的聊天室应用、文件传输服务等,这些案例不仅展示了Socket编程的基本原理,也涵盖了多线程、非阻塞I/O和安全通信等高级主题。通过动手实践,读者可以将理论知识转化为实际技能,更...
"Socket 通信(TCP)非阻塞模式-select 模型" 本资源是关于 Socket 通信的非阻塞模式下的 Select 模型的示例代码,基于 TCP 协议,分为服务器端和客户端。该示例代码展示了如何使用 Select 模型实现非阻塞 Socket ...
Java TCP/IP Socket编程是网络通信领域中的核心技术,广泛应用于服务器端和客户端之间的数据传输。本资源包含第二版书籍的相关源码,旨在帮助开发者深入理解并实践Socket编程。以下是关于Java TCP/IP Socket编程的...
本主题聚焦于使用Java进行基于TCP的Socket编程,通过`File_client.java`和`File_server.java`两个文件来实现服务器和客户端之间的数据交换。 首先,TCP Socket编程的基础是Java的`java.net.Socket`和`java.net....
总之,"C++ TCP客户端非阻塞连接超时测试源码"是一个实用的示例,它展示了如何在C++中处理TCP连接的非阻塞和超时问题,这对于开发高可用性和高性能的网络应用程序至关重要。通过学习和分析这段代码,开发者可以提升...
非阻塞TCP编程是计算机网络通信中的一个重要概念,特别是在高并发和实时性要求较高的系统中。在传统的TCP编程中,通常使用阻塞模式,即一个线程在等待数据到达时会被挂起,直到数据到达才会继续执行。然而,这种模式...
TCP/IP Socket编程是网络编程中的一项基础技能,它涉及到网络通信的底层协议,以及通过套接字API实现客户端和服务器之间通信的方法。下面将详细介绍本书中涵盖的知识点。 首先,计算机网络、分组报文和协议是网络...
5. **异步I/O**:介绍异步Socket编程,如非阻塞I/O和异步事件驱动模型,这对于处理高并发场景至关重要。 6. **错误处理和调试技巧**:书中会讨论常见的Socket编程错误及解决策略,以及如何进行有效的网络调试。 7....
Socket编程在IT领域中是网络通信的基础,尤其在C++编程环境下,利用VC++6.0这样的集成开发环境,开发者可以构建高效的网络应用程序。在这个"socket多线程例程非阻塞模式"的示例中,我们将深入探讨如何在Windows平台...
《TCP-IP Sockets in Java, 2nd Edition》作为外文教材,详细介绍了Java Socket编程的各个方面,包括TCP和UDP协议、套接字选项、异步I/O以及高级主题如NIO(非阻塞I/O)和NLPIJ(网络负载平衡和持久性接口)。...
Socket编程是计算机网络通信的核心技术之一,特别是在C语言环境下,通过TCP协议进行Socket通信能实现稳定、可靠的双向数据传输。本篇文章将详细讲解如何在C语言中实现基于TCP协议的Socket通信。 首先,TCP...
非阻塞 connect 编程的实现思路是,在一个 TCP 套接口设置为非阻塞后,调用 connect,connect 会在系统提供的 errno 变量中返回一个 EINPROGRESS 错误,此时 TCP 的三路握手继续进行。之后可以用 select 函数检查这...
《Java+TCP/IP+Socket编程++原书第2版》是一部深入探讨Java网络编程的权威著作,主要聚焦于TCP/IP协议栈与Socket编程技术。在Java编程领域,掌握网络通信能力是开发分布式系统、服务器端应用以及实时数据传输等项目...