免费注册 查看新帖 |

Chinaunix

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

请问代码优化的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-06-04 12:02 |只看该作者 |正序浏览
本帖最后由 evenstar 于 2012-06-04 12:03 编辑

请问以下代码如何优化,可以使用各种位运算:
  1. int a=b%16;
  2. int a=(b+c)/2;
  3. int a=(b%8)*4;
复制代码

论坛徽章:
0
12 [报告]
发表于 2012-06-04 16:55 |只看该作者
有可能是嵌入式

论坛徽章:
0
11 [报告]
发表于 2012-06-04 14:19 |只看该作者
本帖最后由 AD8018 于 2012-06-04 14:20 编辑

人肉优化,是要挑战编译器专家的智慧。

int a=(b%8 )*4;

能否优化成 a = (b & 7) << 2; 要看情况,
unsigned int b 才成立,int b是不行的。

实际上,某arm指令集无法和立即数 7 做&运算,
取数字7要花时间,在unsigned int b时,不如优化成
a = b << 29 >> 27;

当然了,你花了脑筋,正确的判断出int b 和 unsigned int b的不同后,
用移位代替&写出最终优化结果后,
会发现,直接拿编译器编译a=(b%8 )*4;,生成的代码就是 a = b<<29>>27;

总结来说,同意10楼,引导手下朝这种方向编程的人,是傻B。

论坛徽章:
0
10 [报告]
发表于 2012-06-04 13:46 |只看该作者
evenstar 发表于 2012-06-04 13:43
回复 7# 三月廿七

跟出题的人说:滚你妈B, 迂腐、

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
9 [报告]
发表于 2012-06-04 13:46 |只看该作者
这种运算一般不会是效率的主要瓶颈。除了包含大量运算的项目,如软3d……

论坛徽章:
0
8 [报告]
发表于 2012-06-04 13:43 |只看该作者
回复 7# 三月廿七


    这是出题考查的内容

论坛徽章:
0
7 [报告]
发表于 2012-06-04 13:18 |只看该作者
mirnshi 发表于 2012-06-04 12:07
优化之前,要先考虑是否值得花时间优化。


肯定不值得

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
6 [报告]
发表于 2012-06-04 12:57 |只看该作者
回复 3# sonicling


    有符号的乘除可能不会给你优化到移位的……

百分号什么的……如果是常数的话,也许可以考虑吧……不过似乎做得没这么细……

论坛徽章:
3
寅虎
日期:2013-11-27 07:53:29申猴
日期:2014-09-12 09:24:152015年迎新春徽章
日期:2015-03-04 09:48:31
5 [报告]
发表于 2012-06-04 12:37 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
4 [报告]
发表于 2012-06-04 12:07 |只看该作者
优化之前,要先考虑是否值得花时间优化。
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP