Snowdream
posts - 403, comments - 310, trackbacks - 0, articles - 7
BlogJava
::
首页
::
新随笔
::
联系
::
聚合
::
管理
原来GCC是支持尾递归的递推优化的
Posted on 2008-05-24 02:05
ZelluX
阅读(2470)
评论(1)
编辑
收藏
所属分类:
C/C++
水木上有人贴了个有趣的程序
#include
<
stdlib.h
>
#include
<
stdio.h
>
void
print_forever(
int
n)
{
printf(
"
%d\n
"
, n);
print_forever(n
+
1
);
}
int
main(
int
argc,
char
*
argv[])
{
print_forever(
0
);
return
0
;
}
用gcc -O2编译运行后会不停地打印从0开始的自然数,注意如果编译器没有做优化的话,打印到某个数的时候肯定会发生栈溢出从而程序终止的情况,但这个程序却能一直运行下去,说明编译器做了尾递归优化。
用gcc -O2 -S生成这个程序的汇编代码后证实了这一点。
.L6:
movl
%
ebx,
4
(
%
esp)
addl $
1
,
%
ebx
movl $.LC0, (
%
esp)
call printf
jmp .L6
print_forever的关键部分被优化成了一个n不断增加的死循环。
接下来是分析哪个优化选项处理了尾递归。
用O3 O2 O1三个优化强度编译程序,查看汇编代码后,发现尾递归优化是O2中新增的功能。于是查看O2新开启的优化开关:
gcc -c -Q -O1 --help=optimizers > /tmp/O1-opts
gcc -c -Q -O2 --help=optimizers > /tmp/O2-opts
diff /tmp/O2-opts /tmp/O1-opts | grep enabled
输出结果:
<
-
falign
-
loops [enabled]
>
-
falign
-
jumps [enabled]
>
-
falign
-
labels [enabled]
>
-
fcaller
-
saves [enabled]
>
-
fcrossjumping [enabled]
>
-
fcse
-
follow
-
jumps [enabled]
>
-
fdelete
-
null
-
pointer
-
checks [enabled]
>
-
fexpensive
-
optimizations [enabled]
>
-
fforward
-
propagate [enabled]
>
-
fgcse [enabled]
>
-
finline
-
small
-
functions [enabled]
>
-
foptimize
-
register
-
move [enabled]
>
-
foptimize
-
sibling
-
calls [enabled]
>
-
fpeephole2 [enabled]
>
-
fregmove [enabled]
>
-
freorder
-
blocks [enabled]
>
-
freorder
-
functions [enabled]
>
-
fschedule
-
insns2 [enabled]
>
-
fstrict
-
aliasing [enabled]
>
-
fthread
-
jumps [enabled]
>
-
ftree
-
pre [enabled]
>
-
ftree
-
store
-
ccp [enabled]
>
-
ftree
-
vrp [enabled]
经证实是-foptimize-sibling-calls这个选项实现了尾递归的优化,具体内容可以参看
http://gcc.gnu.org./ml/gcc-patches/2000-03/msg00867.html
评论
#
re: 原来GCC是支持尾递归的递推优化的
回复
更多评论
2013-09-02 22:37 by
darkhorse
我在ubuntu下面汇编的结果是:
print_forever:
pushl %ebp
movl %esp, %ebp
pushl %ebx
subl $20, %esp
movl 8(%ebp), %ebx
.p2align 4,,7
.p2align 3
怎么跟你的不一样?
新用户注册
刷新评论列表
只有注册用户
登录
后才能发表评论。
网站导航:
博客园
IT新闻
Chat2DB
C++博客
博问
管理
相关文章:
内存模型相关的资料
OS Lab 零散记录
MaNGOS阅读笔记 (1)
原来GCC是支持尾递归的递推优化的
C/C++中的序列点
Lab2
C++ 入门笔记 (8) - Object-Oriented Programming
memcpy函数代码分析
在未安装qt的windows系统中运行qt程序
C++ 入门笔记 (7)
Powered by:
BlogJava
Copyright © ZelluX
日历
<
2013年9月
>
日
一
二
三
四
五
六
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
常用链接
我的随笔
我的评论
我的参与
最新评论
留言簿
(21)
给我留言
查看公开留言
查看私人留言
随笔分类
(390)
Algorithm(57)
C/C++(39)
Courses(15)
Economics(2)
Laboratory(25)
Linux(47)
Mathematics(12)
OOP(89)
Scripting(19)
Security(3)
System(28)
Web(10)
书、电影、音乐(11)
其他(14)
点滴(19)
随笔档案
(389)
2009年12月 (1)
2009年4月 (1)
2009年3月 (4)
2009年2月 (2)
2009年1月 (2)
2008年11月 (1)
2008年10月 (9)
2008年9月 (1)
2008年7月 (2)
2008年6月 (4)
2008年5月 (12)
2008年4月 (18)
2008年3月 (7)
2008年2月 (33)
2008年1月 (19)
2007年12月 (8)
2007年11月 (14)
2007年10月 (24)
2007年9月 (18)
2007年8月 (28)
2007年7月 (33)
2007年6月 (26)
2007年5月 (30)
2007年4月 (92)
文章档案
(7)
2007年7月 (2)
2007年5月 (4)
2007年4月 (1)
相册
Illustration
15ers
jonathan的BLOG
Right There...
宙斯鱼的小鱼缸
小鲍的世界
简单幸福
逃遁的Persephone
阿缪尔的锦瑟
风之语的BLOG
友情链接
(04CS) ljh
(05CS) 小菜虎的窝
(06CS) FreePeter
(06SS) Overboming
(06SS) Sherry
(06SS) 十指飞扬
(06SS) 银色子弹
luohandsome的专栏
平淡是真——啃啃不老阁
收藏夹
[ADN.cn]Library
Debian学习笔记
Dictionary of Algorithms and Data Structures
Gollum
Lex&Yacc
Max On Java
techInterview Discussion
核桃仁
程序员面试题精选100题
铁手
搜索
积分与排名
积分 - 341794
排名 - 165
最新随笔
1. 新博客
2. 慎用xen的make world...
3. 内存模型相关的资料
4. 安全方面的经典论文:A Logic of Authentication
5. Lock-Free 算法的几个链接
6. 10 Papers Every Programmer Should Read
7. PieTTY中按Ctrl+S导致挂起的问题解决
8. Finding and Reproducing Heisenbugs in Concurrent Programs
9. Ubuntu 8.10 浏览网页不稳定的解决方法
10. [zz]苏南经济模式兴衰亲历记
最新评论
1. re: C/C++中的序列点
说的太好了,解决我长久的困扰!
--除美灭日平韩
2. re: 原来GCC是支持尾递归的递推优化的
评论内容较长,点击标题查看
--darkhorse
3. re: Arch下配置samba服务
我按照你的方法,安装了SAMBA,但是 /etc/rc.d/samba start 启动不了samba服务。提示不存在这个文件或目录的,怎么办?
--zhangbear
4. re: [zz]LKM Rootkits on Linux x86 v2.6
rhel 5 系列 安装了 Xen 内核, 怎么rootkit xen kernel 呢?
--消息
5. re: CLRS 习题 16.2-6 部分背包问题的O(n)算法
@ynnej
T(n)=2T(n/2)+O(n) 才是 nlgn 注意其中有一个2
--荒废庭院
阅读排行榜
1. [zz]vim+ctags+taglist插件安装使用(18328)
2. memcpy函数代码分析(9408)
3. [zz]Zotero与Endnote的互相导入(8796)
4. BNF 文法 (1) - 语法树 | 二义性的解决(8296)
5. Java泛型中的? super T语法(6577)
评论排行榜
1. C# 学习笔记 (1)(14)
2. Windows - QQ、网页Flash视频无声音的解决方法(14)
3. URAL 1011(10)
4. 《编程之美》上的一道题目的讨论(8)
5. Singleton模式与双检测锁定(DCL)(7)