本来打算先完成一些汇编上的事情,再等以后时间充足的时候,再搞的。

  但是我看着那些源代码,心理确实不是滋味。

  因为不管你是现在做或者以后做,都必须面对这些要命的问题。

  我不知道大家看着下面这个结构,心理是什么感想,我只知道要改的话,比去完成一个IOCP完成端口控件所需要的时间还要多得多。

  

1   TGateInfo = record 
2     Socket: TCustomWinSocket;
3     sIPaddr: string; 
4     sReceiveMsg: string;
5     UserList: TList;
6     dwKeepAliveTick: LongWord;
7   end;

  这个结构就算你采用内存池管理,最后的结果仍然无法避免得了,大量内存碎片的产生。

  看上面红色部分的代码,是两个对象。这两个对象在客户端断开之后是需要清空的,问题大大滴有啊。

  而且有问题的不止这一块,太多了,可能你还必须修改服务器JSocket控件的源代码,呵呵,真晕,对吧。

  为什么IOCP编程里面极端注意对象的使用呢,原因是你需要考虑到,在很短的时间内或者在一段时间内,对象的大量释放和创建都会直接导致内存碎片的产生,从而令到服务器物理性能急剧下降。

  为什么会这样,这个应该涉及到CPU寻址的效率问题,内存碎片越多,CPU所需要的时间会成倍增加,那么对于逻辑代码的执行显然花费的时间就多了。鼠标右键点击桌面,右键菜单老半天都不弹出,这个情况,大家已经是熟悉得不能够再熟悉了。明白了吧。虽然只是个比如,游戏中,显然你损失还要多得多。

  而且这个JSocket控件在面对大并发连接的时候,无论是效率和资源开销都是很成问题的。

  目前大型的网络游戏服务端编程都是采用高并发多线程IOCP完成端口来制作,这个已经不用问了。

 

  网络编程其实有几种模型,有选择类型的、有事件类型的等等,但是最终在Windows系统下,最高效率和完美的就是IOCP模型。

  在同一时间内支持万级以上的连接,非完成端口莫属。

 

  网上关于IOCP的例子有不少,说真的,都不合适使用,只适合做参考用。

  显然,我们不得不自己动手来封装这个服务器控件了。

  下面,我们就动手一步一步来构建属于自己的完成端口服务器控件。

  这之中涉及到很多系统方面的知识。。。做好心理准备啦!!!!!

posted on 2012-08-26 22:17  一笑如风  阅读(2732)  评论(1编辑  收藏  举报