C语言的函数嵌套调用与函数递归调用有什么区别
7个回答
展开全部
区别:
函数的嵌套调用是指在一个C语言函数里面在执行另一个函数,这样通常称为函数的嵌套调用。而函数的递归调用,一般指的是这个C语言函数调用自己本身的函数也就是说调用函数的函数体是一样的,这样称为递归调用。
扩展资料:
函数的分类
从用户使用的角度看,函数有两种:
标准函数,即库函数。这是由系统提供的。用户自定义的函数。可以解决用户的专门需要。
从函数的形式看,函数分两类:
无参函数。printstar和print_message就是无参函数。在调用无参函数时,主调函数并不将数据传送给被调用函数,一般用来执行指定的一组操作。
有参函数。在调用函数时,在主调函数和被调用函数之间有数据传递。也就是说,主调函数可以将数据传递给被调用函数使用,被调用函数中的数据也可以带回来供主调函数使用。
参考资料来源:百度百科—main函数
展开全部
函数的嵌套调用是在一个函数里面调用另一个函数。假如说现在有3个函数,函数A,函数B,函数C,A()—>B()—>C(),这里举其中一种函数嵌套调用方式,函数A里面调用了函数B,函数B里面调用了函数A。代码如下:
void A()
{
B();
}
void B()
{
C();
}
void C()
{
}
函数的递归调用是只函数自身调用函数自身。举例说明
void A()
{
//函数递归结束条件
.......
A();
}
//具体示例函数,使用递归方法求Fibonacci数列
int Fibonacci(int n)
{
int sum;
if(n<=0)
{
printf("参数值非法!\n");
exit(-1); //直接终止程序
}
if(n==1 || n==2) //递归结束条件
return 1;
else
sum=Fibonacci(n-1)+Fibonacci(n-2); //调用函数本身
return sum;
}
递归函数必须要有递归结束条件,否则就会无限递归下去,直至耗尽内存空间。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
嵌套调用,就是函数里面调用函数,调用的是谁没关系,都属于嵌套。
递归调用,就是函数调用本身。必须是自己调用自己。
所以 递归调用是嵌套调用的一种特别形式。
递归调用,就是函数调用本身。必须是自己调用自己。
所以 递归调用是嵌套调用的一种特别形式。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用函数1调用函数2,函数2再调用函数3……原则上没有深度限制,这就是嵌套调用。显然递归调用是典型的嵌套调用,只是递归调用是函数自身调用自己而已……
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
函数嵌套调用主要是指是各个函数间互相调用;
递归调用是在这个函数中调用它本身,自己调用自己
递归调用是在这个函数中调用它本身,自己调用自己
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询