C语言的函数嵌套调用与函数递归调用有什么区别

如题所述

区别:

函数的嵌套调用是指在一个C语言函数里面在执行另一个函数,这样通常称为函数的嵌套调用。而函数的递归调用,一般指的是这个C语言函数调用自己本身的函数也就是说调用函数的函数体是一样的,这样称为递归调用。

扩展资料:

函数的分类

从用户使用的角度看,函数有两种:

标准函数,即库函数。这是由系统提供的。用户自定义的函数。可以解决用户的专门需要。

从函数的形式看,函数分两类:

无参函数。printstar和print_message就是无参函数。在调用无参函数时,主调函数并不将数据传送给被调用函数,一般用来执行指定的一组操作。

有参函数。在调用函数时,在主调函数和被调用函数之间有数据传递。也就是说,主调函数可以将数据传递给被调用函数使用,被调用函数中的数据也可以带回来供主调函数使用。

参考资料来源:百度百科—main函数

温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-09-14

函数的嵌套调用是在一个函数里面调用另一个函数。假如说现在有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;
}

递归函数必须要有递归结束条件,否则就会无限递归下去,直至耗尽内存空间。

第2个回答  推荐于2017-09-14
嵌套调用,就是函数里面调用函数,调用的是谁没关系,都属于嵌套。
递归调用,就是函数调用本身。必须是自己调用自己。
所以 递归调用是嵌套调用的一种特别形式。本回答被网友采纳
第3个回答  2017-08-22
用函数1调用函数2,函数2再调用函数3……原则上没有深度限制,这就是嵌套调用。显然递归调用是典型的嵌套调用,只是递归调用是函数自身调用自己而已……
第4个回答  2017-08-22
函数嵌套调用主要是指是各个函数间互相调用;
递归调用是在这个函数中调用它本身,自己调用自己

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网