免费注册 查看新帖 |

Chinaunix

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

同一段程序, gcc 不同版本得到不同的结果. [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-08-31 15:43 |只看该作者 |倒序浏览
不知是 gcc 的 bug, 还是理解的有误.
大家一起看看, 编译下试试这代码到底会输出什么结果!


  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int bar()
  4. {
  5.     return 20;
  6. }

  7. int main()
  8. {
  9.     int         len = 3;

  10.     printf("%d, %d\n", len=bar(), len);
  11.     return 0;
  12. }
复制代码


测试结果:
gcc 3.4.3, gcc 3.4.4 输出结果为: 20, 20
gcc 3.2.2 及以下输出结果为: 20, 3
VC++ 6.0 输出结果为: 20, 3

该程序在 windows, linux, cygwin (x86, arm, mips) 上均得到同上的结果.

结论:
我们应尽量避免假设函数入栈顺序是自右向左的, 并无畏的加以应用.
不管是编译器bug, 还是其它, 我们都要要考虑不同编译器/版本差异会引起的结果差异.

[ 本帖最后由 newzy 于 2007-8-31 15:47 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-08-31 15:56 |只看该作者
我们应尽量避免假设函数入栈顺序是自右向左的
-----------------
纠正一下,是实参表求值顺序而非入栈顺序。依赖实参表求值顺序或者参数入栈顺序的程序风格就不是好风格。

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
3 [报告]
发表于 2007-08-31 15:58 |只看该作者
原帖由 dozec 于 2007-8-31 15:56 发表
我们应尽量避免假设函数入栈顺序是自右向左的
-----------------
纠正一下,是实参表求值顺序而非入栈顺序。依赖实参表求值顺序或者参数入栈顺序的程序风格就不是好风格。

不仅仅是好风格的问题,
而是有时候它会给你不想要的结果。

论坛徽章:
0
4 [报告]
发表于 2007-08-31 16:00 |只看该作者

回复 #2 dozec 的帖子

长见识了

论坛徽章:
0
5 [报告]
发表于 2007-08-31 17:16 |只看该作者
我也与到了同样的问题

  1. main()
  2. {
  3.     int i=1;
  4.     printf("%d,%d",++i,i++);
  5. }
复制代码

结果:3,1 OR others??

论坛徽章:
0
6 [报告]
发表于 2007-08-31 18:34 |只看该作者
原帖由 ruoyisiyu 于 2007-8-31 17:16 发表
我也与到了同样的问题

main()
{
    int i=1;
    printf("%d,%d",++i,i++);
}

结果:3,1 OR others??



开发中少用这种风格吧

论坛徽章:
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
7 [报告]
发表于 2007-08-31 19:36 |只看该作者
原帖由 newzy 于 2007-8-31 15:43 发表
不知是 gcc 的 bug, 还是理解的有误.
大家一起看看, 编译下试试这代码到底会输出什么结果!


#include
#include

int bar()
{
    return 20;
}

int main()
{
    int         len = 3;

  ...

你的代码有问题。

论坛徽章:
0
8 [报告]
发表于 2007-08-31 20:21 |只看该作者
gcc 3.4.6  是20, 3

论坛徽章:
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
9 [报告]
发表于 2007-08-31 20:29 |只看该作者
原帖由 linux_paly 于 2007-8-31 20:21 发表
gcc 3.4.6  是20, 3

这种东西还是不要试了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP