1.首先说一下函数的副本机制
形式参数会开辟内存,新建一个变量,容纳传递过来的实际参数的值。
看一段简单的代码
1 # include<stdio.h>
2 # include<stdlib.h>
3
4 int add(int n, int m)
5 {
6 int z = n + m;
7 return z;
8 }
9
10 int main()
11 {
12 printf("%d
", add(1, 2));
13 }
当函数返回后,内存已经回收,仍能打印值,这是因为函数的副本机制
2.结构体有副本
1 # include<stdio.h>
2 # include<stdlib.h>
3
4 struct myStruct
5 {
6 int a[5];
7 int n;
8 };
9
10 void change(struct myStruct my1)
11 {
12 my1.n = 0;
13 my1.a[0] = 1000;
14 printf("%d
", &my1);
15 }
16
17 int main1()
18 {
19 struct myStruct my1 = { { 1, 2, 3, 4, 5 }, 100 };
20 printf("%d,%d
", my1.a[0], my1.n);
21 printf("%d
", &my1);
22 change(my1);
23 printf("%d,%d
", my1.a[0], my1.n);
24 system("pause");
25 }
结果:(可以发现没有改变,地址不同)
结论:
1.除了数组没有副本机制,其他都有副本机制
2.结构体有副本机制
3.结构体中就算有数组,也有副本机制
4.结构体数组,单个有副本机制
- 结构体作为参数具有副本机制,结构体返回值也有副本机制 。 函数的参数和返回值都有他的副本机制。
- 数组有副本机制。
- 数组名作为参数会退化为指针。
- 一般情况下不要把结构体变量用作参数,因为值比较多,拷贝起来会很慢,浪费空间浪费时间,最好用地址。