DELPHI中完成端口(摘自掰掰开发).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DELPHI中完成端口(摘自掰掰开发)

DELPHI中完成端口(IOCP)的简单分析掰掰开发-/ 用DELPHI开发网络代码已经有一段时间了! 我发现在网上用VC来实现完成端口(IOCP)的代码很多,但是使用DELPHI来实现的就比较少了。对IOCP讲的清楚的就更少了。在这里我把自己编写DELPHI下的IOCP写出来,希望对刚学完成端口的朋友有个帮助。 首先我们来了解一些在使用IOCP的时候需要使用的一些结构! (1):单IO数据结构 ??LPVOID = Pointer; ??LPPER_IO_OPERATION_DATA = ^ PER_IO_OPERATION_DATA ; ??PER_IO_OPERATION_DATA = packed record ? ? Overlapped: OVERLAPPED; ? ? DataBuf: TWSABUF; ? ? Buffer: array [0..1024] of CHAR; ? ? BytesSEND: DWORD; ? ? BytesRECV: DWORD; ??end; 上面的结构中Overlapped: OVERLAPPED;和DataBuf: TWSABUF;是固定的结构类型。Buffer: array [0..1024] of CHAR;是用来保存接受数据的缓存。BytesSEND: DWORD;用来标志发送数据的长度。BytesRECV: DWORD;用来标志接受数据的长度。因为完成端口的工作者线程可以接受到来自客户端的数据,同时还可以接受到自己发送给客户端的数据,所以我们使用BytesSEND,BytesRECV变量来说是用来区分这次的数据是来自客户端的数据还是自己发送出去的数据。详细的使用方法,我会在下面详细说明。 (2):“单句柄数据结构” ??LPPER_HANDLE_DATA = ^ PER_HANDLE_DATA; ??PER_HANDLE_DATA = packed record ? ? Socket: TSocket; ??end; 下来我从编写一个完成端口的为例说明。 if WSAStartUp($202, wsData) 0 then begin ? ?WSACleanup(); end; 加载SOCKET。我使用的是2.2版为了后面方便加入心跳。 CompletionPort:=CreateIOCompletionPort(INVALID_HANDLE_VALUE,0,0,0); 创建一个完成端口。 GetSystemInfo(LocalSI); for I:=0 to LocalSI.dwNumberOfProcessors * 2 -1 do begin ? ?hThread := CreateThread(nil, 0, @ServerWorkerThread, Pointer(CompletionPort),0, ThreadID); ? ?if (hThread = 0) then ? ?begin ? ?? ? Exit; ? ?end; ? ?CloseHandle(hThread); end; 根据CPU的数量创建CPU*2数量的工作者线程。 Listensc:=WSASocket(AF_INET,SOCK_STREAM,0,Nil,0,WSA_FLAG_OVERLAPPED); if Listensc=SOCKET_ERROR then begin ? ? closesocket(Listensc); ? ? WSACleanup(); end; sto.sin_family:=AF_INET; sto.sin_port:=htons(5500); sto.sin_addr.s_addr:=htonl(INADDR_ANY); if bind(Listensc,sto,sizeof(sto))=SOCKET_ERROR then begin ? ?closesocket(Listensc); end; listen(Listensc,20); 创建一个套接字,将此套接字和一个端口绑定并监听此端口。 while (TRUE) do begin ? ?Acceptsc:= WSAAccept(Listensc, nil, nil, nil, 0); ? ?当客户端有连接请求的时候,WSAAccept函数会新创建一个套接字Acceptsc。这个套接字就是和客户端通信的时候使用的套接字。 ? ?if (Acceptsc= SOCKET_ERROR) then ? ?begin ? ?? ?closesocket(Listensc); ? ?? ?exit; ? ?end; ? ?判断Acceptsc套接字创建是否成功,如果不成功则退出。 ? ?PerHandleD

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档