1.概念解释
1.1值传递:
形参是实参的拷贝,在外部某个函数中改变形参的值并不会影响主函数内的数据。从被调用函数的角度来说,值**传递是单向的(实参->形参),参数的值只能传入,不能传出**,当函数内部需要修改参数,并且不希望这个改变影响调用者时,采用值传递。但是当数据量很大,某个函数只用其中的一部分的时候是不可取的,因为它会把整份数据都拷贝过来。
1.2指针传递:
形参为指向实参地址的指针,当对形参的指向操作时,就相当于对实参本身进行的操作,函数传递的时候只传入一个指针占用四个字节的空间。但是在函数中数据外部数据也会发生改变。
2.代码案例
#include<iostream>
using namespace std;
struct Student
{
string name;
int age;
};
void printStudent1(Student p) {
p.age = 18;
cout << "采用值传递的方式:" << " 姓名:" << p.name << " 年龄: " << p.age << endl;
}
void printStudent2(Student *p) {
p->age = 18;
cout << "采用地址传递的方式:" << " 姓名:" << p->name << " 年龄: " << p->age << endl;
}
int main()
{
Student s = { "张三",15 };
printStudent1(s);
cout << "源结构体的变量:" << " 姓名:" << s.name << " 年龄: " << s.age << endl;
printStudent2(&s);
cout << "源结构体的变量:" << " 姓名:" << s.name << " 年龄: " << s.age << endl;
system("pause");
return 0;
}
结果如下: 可以理解为值传递的时候函数把源数据传递给了新变量,而函数中的更改都是对新变量的操作 指针传递是在函数中传递了指向源数据的指针,函数中的数据都是对源数据的操作 如果指针传递的时候防止误修改可使用const修饰
void printStudent2( const Student *p) {
p->age = 18;
cout << "采用地址传递的方式:" << " 姓名:" << p->name << " 年龄: " << p->age << endl;
}
这时候如果在程序中修改程序会报错
|