免费注册 查看新帖 |

Chinaunix

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

[书评] 《Linux多线程服务端编程:使用muduo C++网络库》有奖试读讨论活动 [复制链接]

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
31 [报告]
发表于 2014-04-25 22:52 |只看该作者
回复 30# yulihua49

这个倒不一定,多CPU并行可以不需要多线程。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
32 [报告]
发表于 2014-05-12 12:19 |只看该作者
windoze 发表于 2014-04-25 22:52
回复 30# yulihua49

这个倒不一定,多CPU并行可以不需要多线程。

不用多线程,用多进程?还是别的技术?
多进程有时不方便共享数据。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
33 [报告]
发表于 2014-05-12 18:46 |只看该作者
回复 32# yulihua49

所谓并行就是在不同的CPU上同时运行多个任务,而进程/线程其实是OS抽象出来的并发结构,这两件事其实没什么关系,多个任务可以位于一个进程/线程内,多个进程也可能只使用一个CPU而不真正的“并行”执行。比如OpenCL中就用Work Item描述并发任务,这东西既不是进程也不是线程,其实和CPU都不一定有关系(可能运行在GPU上)
从底层的角度看,只要你能让代码跑在不同的CPU/GPU上就算完成任务了,对不?

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
34 [报告]
发表于 2014-05-15 14:42 |只看该作者
本帖最后由 yulihua49 于 2014-05-15 15:34 编辑
windoze 发表于 2014-05-12 18:46
回复 32# yulihua49

所谓并行就是在不同的CPU上同时运行多个任务,而进程/线程其实是OS抽象出来的并发结 ...

我现在不知道如何在单线程上并行跑多个CPU,你能介绍些方法吗?
不过程序员关心的是方便性。
一般都是在目态(非管态)编程,控制不了系统底层的资源的。

你说的是理论上。
实际上,我不可能拿着一堆裸CPU自己去写并行计算代码,既不用操作系统,又不用任何语言,也不用任何工具,当然也不存在任何进程和线程,一切从0做起,一切都是具体的,没有任何抽象。
所以,我们要实际些,在当今主流操作系统和常见平台上(本帖已经定义了LINUX),我们怎样开发多CPU,多核的并行处理程序呢?
你说不用多进程和线程,有什么好办法?能在任务的指定时间及可控的成本下完成任务?
如果一个理论,没有现实意义,只是说了一些尽人皆知的废话,那就没必要浪费时间讨论它了。
所以,还是现实些,讨论一下并行处理技术,除非,你的办法比多线程、多进程还高明,还方便,更具实用价值。

看了一下openCL,不过是在编译器中处理,把任务和数据分块,发送到不同的CPU和GPU处理,然后等待结果,综合结果。。。。
这跟我们的工作很相似,我们是把数据分块,发送到多个节点去计算,每个节点是多线程的。
最后收集数据,综合起来得到最终结果。就是map-reduce模型,云计算。。。。。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
35 [报告]
发表于 2014-05-15 17:46 |只看该作者
回复 34# yulihua49

你说的没错啊。
话说回来在Linux里操作裸CPU也没那么遥不可及,启动的时候加个isolcpus参数预留几个CPU,然后就可以写个内核模块独占它们了,类似的事情好像有人做过。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
36 [报告]
发表于 2014-05-16 11:35 |只看该作者
windoze 发表于 2014-05-15 17:46
回复 34# yulihua49

你说的没错啊。

嗯。
楼主说的是用他那个工具进行多线程并行。
看哪个方便吧,多数人关心的是方便性。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP