免费注册 查看新帖 |

Chinaunix

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

[Linux] 一种多进程下的设计模式求指教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-06-09 12:55 |只看该作者 |倒序浏览
遇到的场景是这样的,
主进程负责取任务并更新任务的后续状态,主进程取了任务之后fork让子进程去执行(如果有多个任务就fork多次),子进程需要返回结果给主进程,
那么这个就类似于多个消费者,一个生产者问题,用共享内存+信号量即可解决;
但是上面的这种解决办法是需要对共享内存加锁的,所以我想请教下:有无一个更为高效或者成熟的模型,或者实现方法(不仅限于共享内存),来解决此类问题?


之前有想过用sockpair这种方式来做,感觉不是很高效,所以就想问下在C里面这种问题的解决思路

论坛徽章:
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-06-09 14:05 |只看该作者
建议多线程 或者 socket通信,不要使用共享内存以及共享内存锁。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
3 [报告]
发表于 2013-06-09 16:52 |只看该作者
回复 2# linux_c_py_php

不要使用共享内存以及共享内存锁。 --求解


   

论坛徽章:
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
4 [报告]
发表于 2013-06-11 17:49 |只看该作者
cxytz01 发表于 2013-06-09 16:52
回复 2# linux_c_py_php

不要使用共享内存以及共享内存锁。 --求解


1, 扩展性差, 共享内存和分布式是冲突的.
2, 共享内存容易被破坏, 比如突然掉电, 进程崩溃, 很容易死锁或者内容破损, 无法恢复.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP