udp包排序算法,求优化
时间:2011-04-30
来源:互联网
由于UDP数据包是无序的,在开发过程中一般要作用排序处理,因此本人设计了以下算法来进行排序:
1.开若干个数据接收线程A,若干个数据预处理线程B,若干个数据处理线程C。
2.数据包包头设计有序列号,并用map<int,int> mapX来保存某个套接字当前要处理的序列号,其中key是套接字,value是当前要处理的序列号。
3.A接收到数据后,把数据放入预处理队列m,并唤醒B进行处理。
4.B解析数据包包头,取得包的序列号x。
5.如果x=1,或x与mapX中的序列号一致,则把数据包转移到数据处理队列n,并唤醒C进行处理;否则不处理,跳过以下6~8步骤。
6.设置x=x+1,并保存到mapX。
7.查找m中是否有序列号与x相等的数据包,如果有,则把数据包转移到n,并唤醒C进行处理。
8.循环步骤6~7,直至找不到相对应的序列号为止。
目前觉得步骤6~8效率比较低,看看大家有没有更好的算法。
1.开若干个数据接收线程A,若干个数据预处理线程B,若干个数据处理线程C。
2.数据包包头设计有序列号,并用map<int,int> mapX来保存某个套接字当前要处理的序列号,其中key是套接字,value是当前要处理的序列号。
3.A接收到数据后,把数据放入预处理队列m,并唤醒B进行处理。
4.B解析数据包包头,取得包的序列号x。
5.如果x=1,或x与mapX中的序列号一致,则把数据包转移到数据处理队列n,并唤醒C进行处理;否则不处理,跳过以下6~8步骤。
6.设置x=x+1,并保存到mapX。
7.查找m中是否有序列号与x相等的数据包,如果有,则把数据包转移到n,并唤醒C进行处理。
8.循环步骤6~7,直至找不到相对应的序列号为止。
目前觉得步骤6~8效率比较低,看看大家有没有更好的算法。
作者: beyondtoday_ 发布时间: 2011-04-30
重要的是,可以实现
作者: Harry_lyc 发布时间: 2011-04-30
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28