免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: mjus
打印 上一主题 下一主题

[C] 如何在多线程中保证结果输出顺序与数据输入顺序一样? [复制链接]

论坛徽章:
9
程序设计版块每日发帖之星
日期:2015-10-18 06:20:00程序设计版块每日发帖之星
日期:2015-11-01 06:20:00程序设计版块每日发帖之星
日期:2015-11-02 06:20:00每日论坛发贴之星
日期:2015-11-02 06:20:00程序设计版块每日发帖之星
日期:2015-11-03 06:20:00程序设计版块每日发帖之星
日期:2015-11-04 06:20:00程序设计版块每日发帖之星
日期:2015-11-06 06:20:00数据库技术版块每周发帖之星
日期:2015-12-02 15:02:47数据库技术版块每日发帖之星
日期:2015-12-08 06:20:00
11 [报告]
发表于 2016-08-23 09:50 |只看该作者
本帖最后由 wlmqgzm 于 2016-08-23 09:53 编辑

这个问题还是比较有意思的,
我的思路是: 主线程 分配给N个线程和N个shared_ptr作为返回结果,  每个线程将结果存入shared_ptr, 最后 主线程依次读取并输出结果, 这样也就没有必要做排序了.
用最流行更高大上的说法就是:  主线程做了一次map, 分配多线程执行, 执行完毕, 主线程reduce结果并输出.

论坛徽章:
14
水瓶座
日期:2014-06-10 09:51:0215-16赛季CBA联赛之江苏
日期:2017-11-27 11:42:3515-16赛季CBA联赛之八一
日期:2017-04-12 14:26:2815-16赛季CBA联赛之吉林
日期:2016-08-20 10:43:1215-16赛季CBA联赛之广夏
日期:2016-06-23 09:53:58程序设计版块每日发帖之星
日期:2016-02-11 06:20:00程序设计版块每日发帖之星
日期:2016-02-09 06:20:0015-16赛季CBA联赛之上海
日期:2015-12-25 16:40:3515-16赛季CBA联赛之广夏
日期:2015-12-22 09:39:36程序设计版块每日发帖之星
日期:2015-08-24 06:20:002015亚冠之德黑兰石油
日期:2015-08-07 09:57:302015年辞旧岁徽章
日期:2015-03-03 16:54:15
12 [报告]
发表于 2016-08-24 09:09 |只看该作者
回复 11# wlmqgzm


        请问“N个shared_ptr”怎么给呢?又怎么读呢?

论坛徽章:
9
程序设计版块每日发帖之星
日期:2015-10-18 06:20:00程序设计版块每日发帖之星
日期:2015-11-01 06:20:00程序设计版块每日发帖之星
日期:2015-11-02 06:20:00每日论坛发贴之星
日期:2015-11-02 06:20:00程序设计版块每日发帖之星
日期:2015-11-03 06:20:00程序设计版块每日发帖之星
日期:2015-11-04 06:20:00程序设计版块每日发帖之星
日期:2015-11-06 06:20:00数据库技术版块每周发帖之星
日期:2015-12-02 15:02:47数据库技术版块每日发帖之星
日期:2015-12-08 06:20:00
13 [报告]
发表于 2016-08-24 10:13 |只看该作者
本帖最后由 wlmqgzm 于 2016-08-24 10:32 编辑

回复 12# lxyscls

这个问题比较个性化,
每个项目都不一样, 如果输入输出的结构可以确定的话, 那么在主线程统一申请内存比较好, 申请的内存结构以shared_ptr<struct_xxx>方式传递给工作线程,  最后主线程在输出后也负责把内存统一释放, 各方面都有很好的性能.
如果有些内容是变长的, 就只有在工作线程中申请内存了, 最后主线程在输出后也负责把内存统一释放, TCMalloc的性能略差点.

如果输出结构无法确定, 那么就比较五花八门了, 可能会用类似json这样的结构,  甚至可能要使用文件方式来传递数据. 原则上由主线程给出文件名, 这样主线程就可以按照自己的文件名队列依次输出结果, 就避免了排序.


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP