免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1606 | 回复: 2
打印 上一主题 下一主题

[进程管理] 信号量一次长时间还是多次短时间的问题 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:57:09
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-04-01 14:27 |只看该作者 |倒序浏览
有个Hash表100+个slot,需要定期进行清理,如果一次拿信号量,然后逐一进行清理的话,耗时较长,作为嵌入式网络设备,是不允许某个task拿太长时间信号量的。

所以现在 的实现是分开,需要拿100多次,但是这时Hash表内的内容会发生变化的,比如在清理第50个slot的时候,第一个slot可能已经又有插入的东西的了。


Linux内核代码里面有没有类似 的case,然后怎么解决的?

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
2 [报告]
发表于 2014-04-01 14:50 |只看该作者
回复 1# giant1st
有个Hash表100+个slot,需要定期进行清理,如果一次拿信号量,然后逐一进行清理的话,耗时较长,作为嵌入式网络设备,是不允许某个task拿太长时间信号量的。

所以现在 的实现是分开,需要拿100多次,但是这时Hash表内的内容会发生变化的,比如在清理第50个slot的时候,第一个slot可能已经又有插入的东西的了。

Linux内核代码里面有没有类似 的case,然后怎么解决的?


这种场景应该是比较常见的,但是从你的描述来看,貌似对清理的实时性要求比较高(比如在清理第50个slot的时候,第一个slot可能已经又有插入的东西的了)?

如果对实时性要求不是太高的话,遍历一次,等待固定时间再次遍历,可以使用锁机制,不一定非得用信号量吧。

   

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:57:09
3 [报告]
发表于 2014-04-01 20:04 |只看该作者
回复 2# 瀚海书香

vxworks中我们用的就是 互斥锁,semMCreate()。。。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP