免费注册 查看新帖 |

Chinaunix

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

[C] 如何计算得最快 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-04-27 16:13 |只看该作者 |倒序浏览
1,每个客户都有计算任务A,计算任务B,计算任务C,最后要将这三个计算任务的结果相加,现在有1000个客户,请问如何计算得最快。
方案1,
开一个进程计算所有客户的任务A
开一个进程计算所有客户的任务B
开一个进程计算所有客户的任务C
开一个进程对上面三个结果进行汇总。

方案2,开10个进程,每个进程负责100个客户的计算任务,每个客户的ABC计算任务都是由这个进程完成。

哪个方案好,请问还有没其它更加好的方案。谢谢

论坛徽章:
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-04-27 16:19 |只看该作者
结合一下嘛, 分三种进程, A, B, C, 每一种都是进程组, 这样就高效了.

论坛徽章:
0
3 [报告]
发表于 2013-04-27 16:24 |只看该作者
是的,都有考虑过,但这样做进程是否有点多回复 2# linux_c_py_php


   

论坛徽章:
0
4 [报告]
发表于 2013-04-27 17:07 |只看该作者
既然是计算任务,那么应该是CPU消耗型的,所以开多于CPU个数的进程数无任何意义,所以直接有几个CPU就开几个进程,然后每个CPU绑定一个进程,从头到尾顺序计算即可,尽量减少进程调度切换,充分利用各种cache(CPU、TLB)。
如果有磁盘、网络等其他操作或并发、速度响应等考虑因素,那就是另外一说了。

论坛徽章:
0
5 [报告]
发表于 2013-04-28 00:02 |只看该作者
谢谢你的意见,回复 4# lenky0401


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP