免费注册 查看新帖 |

Chinaunix

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

[Linux] 定时发送信号给另一个进程接收,时间间隔小的时候会出现一直发送的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-25 10:31 |只看该作者 |倒序浏览
写了个测试程序,sigsend负责定时用kill给指定的进程发送SIGCONT,sigrecv则用sigaction接收SIGCONT信号
sigsend每次发送了信号会打印一个“send+time”的信息到console,sigrecv接收到信号也会打印一个“recv+time”的信息到console

sigsend时间间隔比较大的时候,console都是一个“send+time”打印后跟着一个打印
但当sigsend时间间隔设置为50毫秒或者更小时,console有时出现连续好几个“send+time”,然后跟着才是连续好几个“recv+time”

这个是信号发送进入了队列吗?信号的机制问题?有没有什么好方法保证在时间间隔小的时候,还是可以同步的一个send后接着一个recv?


麻烦各位答疑一下

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2013-09-25 11:29 |只看该作者
生产者和消费者速率不同, 因为信号处理延迟和系统调度问题, 放弃吧.

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
3 [报告]
发表于 2013-09-26 14:12 |只看该作者
回复 1# 洋没吐气


    你可以把输出缓冲起来最后一次性输出到文件,打上时间戳更好。因为终端输出设备只有一个(显示器)所以在操作过快(50ms)的时候会产生并发争用(这时终端成race condtion了)。应该问题应该只是纯输出问题引起的小问题。

论坛徽章:
0
4 [报告]
发表于 2013-09-26 22:44 |只看该作者
这个应该跟系统有关,比如系统处理时间的精确度。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP