时间:2022-10-21 09:44:29 | 栏目:C代码 | 点击:次
讲解知识点之前,我们先来做一道题!
写一个函数可以交换两个整形变量的内容
例如:
交换前:20 30
交换后:30 20
题目让我们用函数的方式写
#include <stdio.h> void Swap1(int x, int y) { int z = 0; z = x; x = y; y = z; } int main() { int a = 0; int b = 0; scanf("%d%d", &a, &b); //交换两个变量 printf("交换前: a=%d b=%d\n", a, b); Swap1(a, b); printf("交换后: a=%d b=%d\n", a, b); return 0; }
运行结果:
20 30
交换前: a=20 b=30
交换后: a=20 b=30
咦?怎么回事呢!为什么没有交换成功?
先别急,慢慢往下看!
主函数里面的Swap1(a, b)
中的a
和b
叫做实参(实际参数)
而当我们进到Swap1
函数内部的时候,Swap1(int x, int y)
中的x
和y
叫做形参(形式参数)
所以我们在调用Swap1函数
的时候,是不是把实际参数传给了形式参数?
这个时候结论是这样子的:
什么叫临时拷贝呢?
所以对形参的修改不会影响实参
很明显,刚刚那个代码是错误的,那么如何修改呢?
回想一下刚刚我们写的函数:
Swap1
函数,把a、b
的值传给了x、y
以后,x、y
的空间和a、b
的空间是独立的空间a、b
的修改是不会影响x、y
的,它们之间是没有建立连接的我们再写一个函数命名为:Swap2
,让Swap2
函数内部跟a、b
之间建立联系
那么怎么让它们之间建立联系呢?
答案:指针
#include <stdio.h> void Swap2(int *pa, int *pb) { int z = 0; z = *pa; *pa = *pb; *pb = z; } int main() { int a = 0; int b = 0; scanf("%d%d", &a, &b); //交换两个变量 printf("交换前: a=%d b=%d\n", a, b); Swap2(&a, &b); printf("交换后: a=%d b=%d\n", a, b); return 0; }
代码运行结果:
20 30
交换前: a=20 b=30
交换后: a=30 b=20
我先创建了a、b
变量,a、b里面分别放了20、30
然后我把a的地址
取出来了,放到pa变量
里面去了;
然后我把b的地址
取出来了,放到pb变量
里面去了;
那么pa
就有能力找到a
,pb
就有能力找到b
那么*pa = a
,*pb = b
再定义了一个z变量
用于交换*pa
和*pb
我们来看看刚刚写的代码
#include <stdio.h> void Swap1(int x, int y) { int z = 0; z = x; x = y; y = z; } void Swap2(int *pa, int *pb) { int z = 0; z = *pa; *pa = *pb; *pb = z; } int main() { int a = 0; int b = 0; scanf("%d%d", &a, &b); //交换两个变量 printf("交换前: a=%d b=%d\n", a, b); Swap1(a, b); Swap2(&a, &b); printf("交换后: a=%d b=%d\n", a, b); return 0; }
当我去调用Swap1函数
的时候,我把a、b
本身的变量传到Swap1函数
,这种方式叫:传值调用
当我去调用Swap2函数
的时候,我把a、b
的地址传到Swap2函数
,这种方式叫:传址调用
函数的形参和实参分别占有不同内存块,对形参的修改不会影响实参
传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式。这种传参方式可以让函数和函数外边的变量建立起真正的联系,也就是函数内部可以直接操
作函数外部的变量