免费注册 查看新帖 |

Chinaunix

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

[C] Linux C 程序如何优化性能 [复制链接]

论坛徽章:
1
射手座
日期:2014-08-04 16:49:43
11 [报告]
发表于 2014-03-25 16:10 |只看该作者
回复 1# __slucx__

    我觉得首先要读懂代码再去优化 比用什么工具都强,  话说QT也只是显示个UI界面而已,关键看你后台那些时刻占用资源的循环是如何处理的,,一个结构设计不好的软件 怎么优化都是徒劳的....

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
12 [报告]
发表于 2014-03-25 16:29 |只看该作者
本帖最后由 shan_ghost 于 2014-03-25 16:31 编辑

同意楼上。

锁主要就是起个互斥/保护作用而已。程序结构良好的话,锁操作并不会带来太大影响。

一般来说,的确是80%的性能问题就出在20%的代码上。但性能和性能是不一样的,慢也是没有下限的……

有可能重写了20%的热点代码,不过是从慢到死变成很慢;再做个profiel,又不得不重写另外的20%热点,结果又从很慢变成勉强可以接受的慢;再解决20%,又从勉强可以接受的慢变成看起来很快,但任务一重就慢到死……可这已经是在原有框架下改写60%的代码了,工作量可是重写的好多好多倍(因为得不停的向原有框架妥协,而且很难找到一个两全的妥协方案);推倒重来时,这些代码多半就用不上了。

所以,最好还是先分析程序逻辑,看看究竟水到哪里了,是不是还有挽救价值,然后再针对性解决。

论坛徽章:
0
13 [报告]
发表于 2014-03-25 19:39 |只看该作者
我自己是这么做的:写个脚本在每个函数里面添加日志,把时间都打印出来,执行一遍看看log就知道时间花在哪里了,再针对性地优化。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
14 [报告]
发表于 2014-03-25 21:03 |只看该作者
andloani 发表于 2014-03-25 19:39
我自己是这么做的:写个脚本在每个函数里面添加日志,把时间都打印出来,执行一遍看看log就知道时间花在哪里 ...


直接用 profiling 工具吧,比你这方法快捷方便还可靠。

论坛徽章:
5
2015年迎新春徽章
日期:2015-03-04 09:58:1115-16赛季CBA联赛之上海
日期:2016-01-18 13:24:3015-16赛季CBA联赛之佛山
日期:2016-01-27 10:13:0515-16赛季CBA联赛之北控
日期:2016-08-04 22:33:2115-16赛季CBA联赛之山西
日期:2016-08-06 15:49:33
15 [报告]
发表于 2014-03-25 22:24 |只看该作者
本帖最后由 __slucx__ 于 2014-03-25 22:40 编辑

@shan_ghost 你说的性能检测工具叫啥? 我怎么没有找到?  gprof?

论坛徽章:
5
2015年迎新春徽章
日期:2015-03-04 09:58:1115-16赛季CBA联赛之上海
日期:2016-01-18 13:24:3015-16赛季CBA联赛之佛山
日期:2016-01-27 10:13:0515-16赛季CBA联赛之北控
日期:2016-08-04 22:33:2115-16赛季CBA联赛之山西
日期:2016-08-06 15:49:33
16 [报告]
发表于 2014-03-25 23:18 |只看该作者
但是似乎gprof不支持多线程

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
17 [报告]
发表于 2014-03-26 11:09 |只看该作者
本帖最后由 shan_ghost 于 2014-03-26 11:10 编辑

gprof能在多线程场景正常执行,但只能显示主线程相关的信息。

http://blog.csdn.net/stanjiang2010/article/details/5655143

论坛徽章:
0
18 [报告]
发表于 2014-03-26 16:19 |只看该作者
gprofile吧,有的时候能帮你找到你以前根本想不到的瓶颈。

优化无非就是两步:找到性能瓶颈,优化它,
前者求助于工具比较靠谱,后者就纯靠技术实力了。

论坛徽章:
5
2015年迎新春徽章
日期:2015-03-04 09:58:1115-16赛季CBA联赛之上海
日期:2016-01-18 13:24:3015-16赛季CBA联赛之佛山
日期:2016-01-27 10:13:0515-16赛季CBA联赛之北控
日期:2016-08-04 22:33:2115-16赛季CBA联赛之山西
日期:2016-08-06 15:49:33
19 [报告]
发表于 2014-03-26 17:40 |只看该作者
本帖最后由 __slucx__ 于 2014-03-26 17:41 编辑

回复 17# shan_ghost


    不行啊,我想要看全部的,以及各线程之间的影响,比如锁的冲突

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
20 [报告]
发表于 2014-03-26 18:46 |只看该作者
回复 19# __slucx__


    前面给的链接里就有解决方案。

或者,直接google profile 工具 C,大堆的文章在等着你。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP