[理学]函数调用机制
- 格式:ppt
- 大小:594.02 KB
- 文档页数:50
汇编函数调用汇编语言是一种低级语言,它与计算机硬件紧密相关。
在汇编语言中,函数调用是一项基本操作,它允许程序员将代码划分为不同的模块,使得代码更加清晰、易于维护。
本文将介绍汇编语言中的函数调用,并探讨其实现原理和常见应用。
一、函数调用的概念及作用函数调用是指程序中的一段代码调用了另外一个函数。
通过函数调用,我们可以将一个复杂的问题分解为若干个简单的子问题,使得代码更易于理解和维护。
函数调用的作用不仅仅是代码模块化,还可以实现代码的重用,提高程序的执行效率。
二、函数调用的实现原理在汇编语言中,函数调用的实现原理主要包括以下几个步骤:1. 函数调用前的准备工作:将函数的参数准备好,并将参数压入栈中。
参数的顺序和个数需要与被调用函数的要求相匹配。
2. 跳转到被调用函数:通过跳转指令(如CALL)将程序的控制权转移到被调用函数的入口地址。
同时,将返回地址(即函数调用指令的下一条指令地址)保存到栈中,以便函数执行完毕后返回到函数调用的地方。
3. 执行被调用函数:被调用函数根据参数进行相应的计算和处理,并将结果保存到指定的寄存器或内存中。
4. 返回到函数调用的地方:被调用函数执行完毕后,通过返回指令(如RET)将程序的控制权返回到函数调用的地方。
同时,将返回值保存在指定的寄存器或内存中,以便函数调用后续的处理。
三、函数调用的常见应用函数调用在汇编语言中有着广泛的应用,下面列举几个常见的应用场景:1. 子程序的调用:程序中的某段代码需要被多次调用,可以将其封装成一个函数,通过函数调用的方式实现代码的重用。
2. 中断处理:当发生硬件中断时,处理器会自动跳转到相应的中断处理函数。
中断处理函数的执行完毕后,再返回到中断发生的地方继续执行。
3. 系统调用:操作系统提供了一系列的系统调用函数,用于访问操作系统的各种功能。
程序通过调用系统调用函数来实现对操作系统的请求和操作。
4. 递归调用:函数调用自身的过程称为递归调用。
c语言函数自我调用C语言函数自我调用自我调用是指函数在执行过程中调用自身的行为。
在C语言中,函数自我调用是一种常见的编程技巧,可以用来解决一些需要重复执行的问题,如递归算法等。
本文将详细介绍C语言函数自我调用的原理、应用场景以及注意事项。
一、函数自我调用的原理函数自我调用的原理是通过在函数体内部使用函数名来调用函数本身。
当函数被调用时,会创建一个新的函数执行上下文,并将参数传递给新的函数。
在函数内部,可以通过条件判断语句来决定是否继续调用函数自身,从而实现重复执行的效果。
二、函数自我调用的应用场景1. 递归算法:递归是指函数调用自身的过程。
递归算法常用于解决具有递归结构的问题,如求解阶乘、斐波那契数列等。
通过函数自我调用,可以简化递归算法的实现,使代码更加简洁和可读。
例如,以下是一个计算阶乘的递归函数:```cint factorial(int n) {if (n == 0 || n == 1) {return 1;} else {return n * factorial(n - 1);}}```2. 链表操作:链表是一种常见的数据结构,通过指针将一组节点按顺序连接起来。
在对链表进行操作时,函数自我调用可以用来遍历链表、查找节点等。
例如,以下是一个递归函数,用于计算链表的长度:```cint getLength(Node* head) {if (head == NULL) {return 0;} else {return 1 + getLength(head->next);}}```3. 树的遍历:树是一种重要的数据结构,常用于表示层次结构的数据。
在对树进行遍历时,函数自我调用可以用来实现先序遍历、中序遍历、后序遍历等。
例如,以下是一个递归函数,用于实现树的先序遍历:```cvoid preOrderTraversal(TreeNode* root) {if (root != NULL) {printf("%d ", root->value);preOrderTraversal(root->left);preOrderTraversal(root->right);}}```三、函数自我调用的注意事项1. 递归终止条件:递归函数必须包含一个终止条件,否则会导致无限递归,最终导致栈溢出。
函数自我调用介绍函数自我调用是指在函数内部调用自身的一种编程技术。
当一个函数在执行过程中需要多次重复类似的操作时,可以使用函数自我调用来简化代码和提高效率。
这种技术在递归算法中应用广泛,能够处理复杂的问题,使代码更加灵活和可读。
实现原理函数自我调用的实现原理是利用函数调用栈。
当一个函数被调用时,系统会为该函数分配一个新的栈帧,用来保存函数的局部变量和返回地址等信息。
当一个函数调用另一个函数时,当前函数的栈帧会被保存到栈中,然后为新函数分配一个新的栈帧,新函数执行结束后再从栈中恢复上一个函数的栈帧,继续执行。
在函数自我调用中,当函数在执行过程中需要执行自身时,会创建新的栈帧,然后将函数的参数传递给自身,并执行自身的代码。
这样就能够实现函数的递归调用,处理问题的过程中不断地调用自身,直到达到终止条件才停止递归。
递归与迭代的区别递归和迭代都是处理重复操作的常用技术,但它们在实现方式和使用场景上有所不同。
实现方式•递归是通过函数自身的调用来实现的,每次调用会创建新的栈帧,执行完毕后再恢复上一个栈帧。
递归是一种自顶向下的操作方式。
•迭代是通过循环来实现的,每次循环执行一次操作,直到达到终止条件才停止循环。
迭代是一种自底向上的操作方式。
使用场景•递归适合处理具有递归结构的问题,如树、图等。
递归能够简洁地表达问题的递归定义,逻辑清晰明了,但对于大规模的问题可能会导致堆栈溢出的问题。
•迭代适合处理规模较大的问题,通过循环的方式逐步求解,不涉及函数调用的开销。
迭代通常会使用辅助变量来保存中间结果,节省内存空间。
递归的基本结构递归函数通常包含两个部分:基本情况和递归情况。
基本情况是指函数不再进行递归调用的条件,一般是指达到了问题的终止条件,不需要再进行递归。
递归情况是指函数仍然需要进行递归调用的情况,根据问题的特性进行自我调用。
一个常见的例子是计算阶乘。
阶乘的定义如下:n! = n * (n-1) * (n-2) * ... * 1可以用递归的方式来计算阶乘:def factorial(n):if n == 0:return 1else:return n * factorial(n-1)在这个例子中,基本情况是当 n 等于 0 时,阶乘的值为 1,不再进行递归调用;递归情况是当 n 大于 0 时,将 n 乘以 factorial(n-1),然后再返回乘积。
函数调用和消息传递一、引言在计算机编程领域,函数调用和消息传递是两种常见的方法,用于在程序中执行特定的任务和传递信息。
函数调用是指通过使用函数的名称和参数来调用函数,以执行函数内的代码块并返回结果。
而消息传递是一种更加灵活的机制,它允许对象之间通过发送消息来交互和通信。
二、函数调用1. 基本概念函数调用是一种程序控制流的机制,通过调用函数来执行特定的任务。
函数定义了一系列的操作,并可以接受输入参数来完成特定的工作。
函数调用的过程包括传递参数、执行函数体中的代码和返回结果。
2. 函数调用的语法函数调用的语法通常包括函数名和参数列表。
函数名指定要调用的函数,而参数列表则传递给函数的输入参数。
# Python的函数调用示例result = my_function(arg1, arg2)3. 函数调用的流程函数调用的流程包括以下几个步骤: 1. 将函数调用的参数传递给函数所需的参数。
2. 执行函数体中的代码块。
3. 返回函数的结果。
4. 函数调用的特点函数调用具有以下几个特点: - 函数可以被多次调用,以便重复利用相同的代码。
- 函数可以返回一个值给调用者,用于获取函数的执行结果。
- 函数调用可以嵌套,即一个函数可以在另一个函数内部被调用。
三、消息传递1. 基本概念消息传递是一种对象之间的通信机制,通过发送消息来实现对象之间的交互和通信。
在面向对象编程中,对象是程序中的基本单位,它们具有自己的状态和行为。
通过发送消息,对象可以调用其他对象的方法,获取返回的结果,并更新自己的状态。
2. 消息传递的语法消息传递的语法通常包括消息的接收者和消息的内容。
接收者指定了消息应该发送给哪个对象,而消息的内容则描述了要执行的具体操作。
# Ruby的消息传递示例result = receiver.message(content)3. 消息传递的流程消息传递的流程包括以下几个步骤: 1. 根据消息的接收者,找到对应的对象。
函数的定义及调用方法在编程中,函数是一段可以重复使用的代码块,它接收输入参数并执行特定的任务,然后返回一个结果。
函数的定义和调用是编程中非常基础且重要的概念,本文将详细介绍函数的定义及调用方法。
一、函数的定义函数的定义包括函数名、参数列表、函数体和返回值。
函数名是函数的标识符,用于在程序中唯一标识该函数。
参数列表是函数接收的输入参数,可以有零个或多个参数。
函数体是函数执行的具体代码逻辑,用于实现函数的功能。
返回值是函数执行完成后返回的结果。
函数的定义一般遵循以下的语法格式:```def function_name(parameter1, parameter2, ...):# 函数体# 执行具体的任务return result```其中,`def`是定义函数的关键字,`function_name`是函数的名称,`parameter1, parameter2, ...`是函数的参数列表,`:`表示函数定义的结束,`return`用于返回函数的结果,`result`是返回的结果值。
二、函数的调用函数的调用是指使用函数名和相应的参数来执行函数。
通过函数的调用,可以在程序中多次重复使用相同的功能。
函数的调用一般遵循以下的语法格式:```result = function_name(argument1, argument2, ...)```其中,`function_name`是要调用的函数名,`argument1, argument2, ...`是要传递给函数的参数值,`result`是函数执行完成后返回的结果。
三、函数的参数函数的参数可以分为两种类型:必需参数和可选参数。
必需参数是函数定义时必须要求提供的参数,调用函数时必须传递相应的参数值。
可选参数是函数定义时给定默认值的参数,调用函数时可以选择性地传递参数值,如果不传递则使用默认值。
四、函数的返回值函数的返回值是函数执行完成后返回的结果。
在函数体中,可以使用`return`语句来返回函数的结果。
Python函数调用规则1. 概述函数是Python编程中非常重要的概念,它们可以将一段代码封装起来,通过调用函数来执行代码,提高代码的可读性和重用性。
本文将详细介绍Python函数的调用规则,包括函数的定义、函数的调用方式、函数参数的传递等。
2. 函数的定义在Python中,使用关键字def来定义函数,语法如下:def function_name(parameters):"""函数的文档字符串"""# 函数体return result•function_name是函数的名称,遵循标识符的命名规则;•parameters是函数的参数列表,多个参数之间用逗号分隔;•"""函数的文档字符串"""用于描述函数的功能和使用方法,可选;•函数体是一段被缩进的代码块,用于定义函数的实现逻辑;•return语句用于返回函数的结果,可选。
3. 函数的调用方式在Python中,可以通过以下几种方式来调用函数:(1)直接调用函数定义完成后,可以直接通过函数名加括号的方式来调用函数,参数传递在括号中进行,如:result = function_name(arg1, arg2, ...)调用时,需要将对应的参数传递给函数,可以有多个参数,用逗号隔开。
(2)赋值调用可以将函数赋值给一个变量,然后通过该变量调用函数,如:func = function_nameresult = func(arg1, arg2, ...)此时,func可以作为一个函数对象来进行调用。
(3)作为参数传递Python中的函数是一等对象(first-class object),可以作为参数传递给其他函数,如:def func1():print("Hello")def func2(func):func()func2(func1) # 输出:Hello在上述示例中,func2函数接收一个函数参数func,然后调用该函数。
函数调用关系
函数调用关系是指函数调用的次序以及函数之间的依赖关系。
函数调用关系可以帮助程序员理解一个特定函数的全部调用情况,从而调试程序、对程序进行优化和进行更高层的软件分析,是软件开发过程中的重要工具。
函数调用关系是基于函数调用的情况进行描述的,每一次函数调用都会生成一个新的函数调用关系。
有三类函数调用关系,分别是直接调用关系、间接调用关系和跨层调用关系。
一、直接调用关系
直接调用关系是指函数在一层内被直接调用,也就是说被调用的函数位于调用它的函数的同一个函数层中。
在直接调用关系中,被调用的函数要么是被调用的函数的子函数,要么是同级函数。
二、间接调用关系
间接调用关系是指函数在不同层之间进行调用,也就是说被调用的函数位于调用函数的上级层中。
当调用的函数跨层使用时,就会产生间接调用关系。
三、跨层调用关系
跨层调用关系是指不同层函数之间的调用关系。
在跨层调用关系中,被调用的函数位于调用它的函数的上级层,也就是说被调用的函数位于调用函数的上一层或更多层之中。
跨层调用关系的复杂程度取决于被调用的函数和调用函数之间的层次关系,一般调用越深,跨层调用关系就越复杂。
函数调用关系可以帮助程序员管理工程,编写更高效的程序,并且了解程序之间的依赖关系。
它也可以用于程序调试、模块化编程和程序优化,从而提升程序效率。
另外,函数调用关系还可以帮助程序员识别函数之间的关联及其调用顺序,也可以用来验证程序的可靠性,以及检查程序的安全性。
总而言之,函数调用关系是程序员理解正确理解和调试程序的必备工具,只要程序员正确理解函数调用关系,就能够有效地管理和改进程序。
函数的定义与调⽤⾸先来了解⼀下概念;1.函数的定义:函数的定义就是对函数所要完的操作进⾏描述,即编写⼀段程序,使该段程序完成函数所指定的操作。
⼀般函数需要先定义后使⽤。
没有定义的函数不能使⽤。
-除主函数外的函数不能单独运⾏,这些函数可以被主函数或其他函数调⽤,也可以条⽤其他函数,但不能调⽤主函数。
2.函数的调⽤:程序中使⽤已经定义好的函数,成为函数调⽤。
定义函数的⽬的是为了使⽤这个函数,因此要学会正确使⽤这个函数。
如果函数A调⽤函数B,则称函数A为主调函数,函数B为被调函数。
函数参数:函数调⽤作为⼀个函数的实参。
例如:z=max(max(a,b),c);其中max(a,b)是⼀次函数调⽤,它的值作为max另⼀次调⽤的实参。
z的值时a,b,c三者中的最⼤者。
/*在这⾥补充⼀下形参与实参的区别,我借⽤⼀下百度上⼀位⽤户的回答:1、形参变量只有在被调⽤时才单元,在调⽤结束时,即刻释放所分配的内存单元。
因此,形参只在函数内部有效。
函数调⽤结束返回主调⽤函数后则不能再使⽤该形参变量。
2、实参可以是常量、变量、表达式、函数等,⽆论实参是何种类型的量,在进⾏函数调⽤时,它们都必须有确定的值,以便把这些值传送给形参。
因此应预先⽤赋值,输⼊等办法使参数获得确定值。
3、实参和形参在数量上,类型上、顺序上应严格⼀致,否则就会发⽣类型不匹配的错误。
4、在⼀般传值调⽤的机制中只能把实参传送给形参,⽽不能把形参的值反向地传送给实参。
因此在函数调⽤过程中,形参值发⽣改变,⽽实参中的值不会变化。
⽽在的机制当中是将实参引⽤的地址传递给了形参,所以任何发⽣在形参上的改变实际上也发⽣在实参变量上。
*/下⾯再来看⼀下具体的实例;a.定义⽆参函数#include <stdio.h>void main(){void print_message(); //对print_message函数的声明print_message(); //调⽤print_message函数}void print_message() //定义print_message函数{printf("How do you do!\n");}b.定义有参函数#include <stdio.h>int main(){int a,b,c=0;int bigger(int,int); //此步骤不能少,需要声明bigger函数,其实bigger函数就是max函数printf("please input two numbers:");scanf("%d%d",&a,&b);c=bigger(a,b); //调⽤bigger函数printf("The max one is%d!",c);}int bigger(int m,int n) //定义bigger函数{if (m > n)return m;elsereturn n;}函数调⽤中:所有函数都是平⾏的,即在定义函数时是分别进⾏的,是互相独⽴的。
C语言函数调用原理
函数调用原理是指在C语言程序中,通过函数的调用来实现
代码的重用和模块化的编程方式。
函数调用原理主要涉及栈、函数调用过程和参数传递等方面。
在C语言中,当需要调用一个函数时,首先需要将函数的信
息压入栈中。
栈是一种后进先出(LIFO)的数据结构,用于
存储函数调用时产生的临时数据和函数调用的返回地址。
栈顶指针指向栈中当前可用的位置,当调用函数时,栈顶指针会向下移动,为函数的局部变量和参数分配空间。
当调用函数时,程序会将调用函数的返回地址压入栈中,并跳转到被调用函数的入口地址开始执行。
被调用函数执行完毕后,会通过返回指令将控制权和返回值返回到调用函数。
在函数调用过程中,还涉及参数的传递。
C语言中的参数传递
方式包括值传递、地址传递和指针传递。
对于简单类型的参数,如整型或字符型,一般采用值传递方式,即将参数的值复制一份传递给函数,不影响原始变量的值。
对于复杂类型参数,如数组或结构体,一般采用地址传递方式,即将参数的地址传递给函数,函数可以通过指针访问和修改参数的值。
总结起来,C语言的函数调用原理主要涉及栈、函数调用过程
和参数传递等方面。
通过函数的调用,可以实现代码的重用和模块化,提高程序的可读性和可维护性。
函数调⽤的四种⽅式在JavaScript中⼀共有4种调⽤模式:函数调⽤模式⽅法调⽤模式构造器调⽤模式间接调⽤模式,通过call()和apply()进⾏1. 函数调⽤模式普通函数调⽤模式,如:function printProps(o){……}printProps({x:1});在⼀个调⽤中,(1)每个参数表达式计算的结果作为实参传递给声明函数时定义的形参;(2)this被绑定到全局变量var myObject = {value:1};value = 2;myObject.printProps = function(){var printValue = function(){console.log(this.value);};printValue();console.log(this.value);}myObject.printProps();此时的运⾏结果是:21我们注意到,在printValue()函数在执⾏时,this.value值为2,也就是说,this指向的是全局对象,⽽不是myObject。
(3)返回值:函数的返回值成为调⽤表达式的值。
I. 如果函数返回是解释器到达结尾,也就是没有执⾏到return XXX的语句。
返回值为undefined。
II. 如果函数返回是因为接受器执⾏到return xxx语句,返回return之后的值。
III. 如果return语句后没有值,即return,则返回undefined。
2. ⽅法调⽤模式当⼀个函数被保存为对象的⼀个属性时,称为⽅法。
(1)参数和返回值的处理与函数调⽤⼀致;(2)调⽤上下⽂this为该对象function printValue(){console.log(this.value);}var value=1;var myObject = {value:2};myObject.m = printValue;//作为函数调⽤printValue();//作为⽅法调⽤myObject.m();运⾏结果为:12我们注意到,当调⽤printValue时,this绑定的是全局对象,打印全局变量value值1。
函数调用的一般形式1.引言1.1 概述函数是编程中的一个重要概念,它可以将一段代码封装成一个可重用的模块,使得程序结构更清晰、易于理解和维护。
函数调用则是指在程序中使用函数的过程,通过调用函数,我们可以执行该函数中的代码,从而实现特定的功能。
在这篇文章中,我们将探讨函数调用的一般形式。
我们会首先介绍函数调用的定义和作用,然后详细讨论函数调用的基本形式。
函数调用是指在程序中使用函数的语法结构。
它通常由函数名、参数和返回值组成。
在函数调用中,我们通过使用函数名来指定要调用的函数,通过向函数传递参数来提供必要的信息,然后函数会执行其内部的代码逻辑,并最终返回一个值。
函数调用的作用是使得程序更加模块化和可重用。
通过将一段功能相关的代码封装成函数,我们可以在需要时多次调用该函数,而不需要重复编写相同的代码。
这样不仅可以提高代码的可读性和可维护性,还可以减少代码的冗余,提高开发效率。
函数调用的基本形式包括函数名、参数和返回值。
函数名用于指定要调用的函数,它是函数在程序中的唯一标识符。
参数是在函数调用时向函数传递的输入值,它可以是零个或多个,用于提供函数执行所需的数据。
返回值则是函数在执行完成后返回给调用者的结果,它可以是任意类型的值。
在函数调用时,我们需要按照函数的定义和规定来传递参数,并根据函数的返回类型来接收返回值。
通过合理使用函数调用,我们可以更好地组织和管理程序的逻辑结构,提高代码的可读性和可维护性。
综上所述,函数调用是程序中使用函数的一种语法结构,它可以将一段代码封装成一个可重用的模块,并通过向函数传递参数和接收返回值来实现特定的功能。
函数调用的一般形式包括函数名、参数和返回值,通过合理使用函数调用,我们可以提高程序的结构化程度和代码的可维护性。
1.2文章结构1.2 文章结构本文将以"函数调用的一般形式"为主题,深入探讨函数调用在编程中的定义、作用以及基本形式。
文章结构如下:引言:在本部分,我们将首先概述函数调用的概念和重要性,并介绍本文的结构和目的。
第1篇一、实验目的1. 理解函数调用的基本概念和原理。
2. 掌握函数定义和调用的方法。
3. 学会使用函数进行模块化编程,提高代码的可读性和可维护性。
4. 熟悉函数的参数传递和返回值。
二、实验环境1. 操作系统:Windows 102. 编程语言:Python3.83. 开发工具:PyCharm三、实验内容1. 函数定义2. 函数调用3. 参数传递4. 返回值5. 递归函数6. 高阶函数四、实验步骤1. 函数定义(1)创建一个名为`sum`的函数,用于计算两个数的和。
```pythondef sum(a, b):return a + b```(2)调用`sum`函数,传入两个数`1`和`2`。
```pythonresult = sum(1, 2)print(result) 输出:3```2. 参数传递(1)创建一个名为`swap`的函数,用于交换两个变量的值。
```pythondef swap(a, b):a, b = b, areturn a, b```(2)调用`swap`函数,传入两个变量`x`和`y`。
```pythonx = 1y = 2x, y = swap(x, y)print(x, y) 输出:2 1```3. 返回值(1)创建一个名为`get_max`的函数,用于获取两个数中的最大值。
```pythondef get_max(a, b):return a if a > b else b```(2)调用`get_max`函数,传入两个数`3`和`5`。
```pythonmax_value = get_max(3, 5)print(max_value) 输出:5```4. 递归函数(1)创建一个名为`factorial`的函数,用于计算一个数的阶乘。
```pythondef factorial(n):if n == 1:return 1else:return n factorial(n - 1)```(2)调用`factorial`函数,传入一个数`5`。
函数定义与调用函数是一种封装了一组可重复使用的代码的机制。
在编程中,函数的定义和调用是非常重要的概念。
本文将介绍函数的定义和调用过程,并以Python语言为例进行说明。
一、函数的定义函数的定义是指在程序中创建一个函数,并用一些语句实现函数的功能。
函数的定义一般包括函数名、参数和函数体这几个部分。
1. 函数名函数名是函数的标识符,用来标识函数的名称。
在定义函数时,需要给函数命名,以便在调用函数时可以通过函数名来引用对应的功能。
函数名应该具有描述性,以便于理解和记忆。
2. 参数参数是函数的输入值,用于向函数传递数据。
函数可以有零个或多个参数。
参数允许在函数内部使用,并可以根据需要进行修改和传递给其他函数。
参数可以是必需的(必须传递的值),也可以是可选的(不必传递的值)。
3. 函数体函数体是函数的具体实现部分,由一组语句组成。
函数体中的语句可以是任何合法的程序语句,包括变量定义、条件判断、循环操作等。
函数体的主要目的是实现函数的功能。
二、函数的调用函数的调用是指在程序中使用函数的功能。
函数的调用一般通过函数名和参数的方式进行。
1. 函数名函数的调用需要使用函数名来引用对应的函数。
通过函数名,程序可以找到对应的函数定义,并执行函数内部的语句。
2. 参数函数的调用需要提供相应的参数值,作为函数的输入。
参数值可以是常量、变量、表达式等。
参数值会被传递给函数,在函数内部被使用。
三、函数的定义和调用示例下面通过一个简单的示例来演示函数的定义和调用过程。
考虑一个函数,用于计算两个数的加法。
```pythondef add_numbers(a, b):sum = a + breturn sumresult = add_numbers(3, 5)print(result)```以上代码中,我们定义了一个名为add_numbers的函数,该函数接收两个参数a和b,并计算它们的和。
在调用函数时,我们传递了两个整数3和5作为参数,并将返回值存储在result变量中。
函数调用的三种方式
在C语言中函数调用的三种方式分别是:传值调用,引用调用和传地址调用。
1、传值调用
传值调用,就是把一个变量的值传递给函数的形式参数,实际就是用变量的值来新生成一个形式参数,形参运算后在把值返回。
函数中改变的值是不能影响到外界的,因而在函数里对形参的改变不会影响到函数外的变量的值。
没有交互成功原因是:使用传值调用,只在形参上改变了数值,没有在实参上改变数值。
2、传地址调用
传地址调用,就是将变量的地址直接传入函数,它把一个变量的地址赋给函数里形式参数的指针,使指针指向真实的变量的地址,因为对指针所指地址的内容的改变能反映到函数外,也就是能改变函数外的变量的值。
交互成功的原因是:使用传地址调用,利用指针改变了原来的地址,所以实参就交换了。
3、引用调用
引用调用实际是通过指针来实现的,把变量的引用传入函数;能达到使用地址调用的效果,可是使用方式如传值调用,函数可以对其值进行修改。
交互成功的原因是:使用引用调用,引用是直接改变两个实参变
量a,b的值,所以就交换了。