免费注册 查看新帖 |

Chinaunix

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

[C] 请大家帮帮看看一个gcc的问题,谢谢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-07-29 14:03 |只看该作者 |倒序浏览
代码如下,在不同的gcc版本下,分别使用
gcc test.c
gcc test.c -O2
编译,运行的结果不同,请大家帮忙看看为什么?哪里能看到各个版本gcc对应的-O2都有哪些选项,谢谢
我试了:
gcc3.4.6,运行结果都是5.000000
gcc4.6.3,运行结果都是5.000000
gcc4.1.2和gcc4.1.0分别是5.000000和0.000000



/*test.c*/
#include <stdio.h>

float test(void)
{
    unsigned int a = 0x40a00000; /*float 5.0*/
    float fa = *(float *)&a;
    return fa;
}

int main()
{
    float fa = test();
    printf("%f\n", fa);
    return 0;
}

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [报告]
发表于 2013-07-29 14:37 |只看该作者
本帖最后由 bruceteen 于 2013-07-30 08:37 编辑

已删除(根据Aquester大侠在11楼的指示,这是未定义行为)

论坛徽章:
0
3 [报告]
发表于 2013-07-29 15:10 |只看该作者
这个只有贴汇编看看区别了。

论坛徽章:
9
摩羯座
日期:2013-08-15 15:18:48狮子座
日期:2013-09-12 18:07:47金牛座
日期:2013-09-16 13:23:09辰龙
日期:2013-10-09 09:03:27白羊座
日期:2013-10-17 13:32:44子鼠
日期:2014-04-23 15:09:38戌狗
日期:2014-09-17 11:37:542015年亚洲杯之韩国
日期:2015-03-26 10:16:442015亚冠之武里南联
日期:2015-08-18 14:55:52
4 [报告]
发表于 2013-07-29 15:24 |只看该作者
出错的那个版本,编译时试一下-fno-strict-aliasing这个参数

论坛徽章:
0
5 [报告]
发表于 2013-07-29 15:25 |只看该作者
本帖最后由 junecl 于 2013-07-29 15:26 编辑

应该是编译选项的问题,fstrict-aliasing,但是对其不了解,所以俺解释不了

论坛徽章:
0
6 [报告]
发表于 2013-07-29 15:26 |只看该作者
还有一个奇怪的问题,在redhat下面
[root@localhost test]# gcc -Q --help=optimizers -O2
gcc: no input files

这是为什么?在ubuntu下就可以

论坛徽章:
0
7 [报告]
发表于 2013-07-29 15:28 |只看该作者
本帖最后由 junecl 于 2013-07-29 15:29 编辑

回复 4# w_anthony

是这个选项的问题,出错的那个版本 gcc test.c -O2 -fno-strict-aliasing  就输出5.00000,我想知道难道只有gcc4.1.x的几个版本才这样吗?谢谢


   

论坛徽章:
0
8 [报告]
发表于 2013-07-29 15:29 |只看该作者
可能是因为type-punning,编译链接时,加“-fno-strict-aliasing”看看?

gcc test.c -O2 -fno-strict-aliasing

论坛徽章:
0
9 [报告]
发表于 2013-07-29 15:35 |只看该作者
回复 8# Aquester

谢谢,是这样的

但是为什么只有gcc4.1.2和4.1.0是这样的?而4.6.3和他们有不同

我把我的redhat的gcc升级到4.1.2,想看看-O2开了哪些优化,可 gcc -Q --help=optimizers -O2用不了,报错gcc: no input files

还在想办法,呵呵


   

论坛徽章:
9
摩羯座
日期:2013-08-15 15:18:48狮子座
日期:2013-09-12 18:07:47金牛座
日期:2013-09-16 13:23:09辰龙
日期:2013-10-09 09:03:27白羊座
日期:2013-10-17 13:32:44子鼠
日期:2014-04-23 15:09:38戌狗
日期:2014-09-17 11:37:542015年亚洲杯之韩国
日期:2015-03-26 10:16:442015亚冠之武里南联
日期:2015-08-18 14:55:52
10 [报告]
发表于 2013-07-29 15:39 |只看该作者
回复 7# junecl


    我被这个坑过,比如
  1. int i=0;
  2. *(((short*)&i) + 1) = 1;
  3. printf("%x", i);
复制代码
结果打印出来不是10000,而是0。
因为fstrict-aliasing认为不同类型的变量不会占用相同的内存块(除union外),然后它就可能以此为前提进行一些额外的优化。
不过写C的,怎么可能保证得了这一点,所以一直老实加上-fno-strict-aliasing
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP