sibcall-7.c

来自「用于进行gcc测试」· C语言 代码 · 共 47 行

C
47
字号
/* Simple check that tail recursive call optimization is also   controlled by -foptimize-sibling-calls.   Copyright (C) 2006 Free Software Foundation Inc.   Original test by Hans-Peter Nilsson  <hp@bitrange.com>  *//* On IA64 the call frame is allocated on the register stack, not the   normal stack.  *//* { dg-do run { target { ! "ia64-*-*" } } } *//* { dg-options "-O2 -fno-optimize-sibling-calls" } */extern void abort (void);extern void recurser_void (int);extern void track (int);int main (void){  recurser_void (0);  return 0;}void recurser_void (int n){  if (n == 0 || n == 7)    track (n);  if (n == 10)    return;  recurser_void (n + 1);}void *trackpoint;void track (int n){  char stackpos[1];  if (n == 0)    trackpoint = stackpos;  else if (n != 7 || trackpoint == stackpos)    abort ();}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?