传值调用
是默认的参数传递机制,实参会复制给形参,调用的语义是每次取得实参的副本并将该复本用作形参,即会有复本的开销,并且不改变实参的值。 适用于:传值调用用于不应该被函数改变的小型对象。
例子:void demo1(int a ,int b);
引用调用
省去了副本的开销,但会改变实参的值。适用于:引用调用用于可能会被函数改变的对象。
例子:void demo2(int & a,int &b);
常数引用调用
为了取得和传值调用一样的效果,即不改变实参的值,使用这种调用形式。它消除了副本的开销,同时不改变实参。 适用于:常量引用调用用于不应该被函数改变的大型对象。
例子:void demo3(const vector &a ,const vector &b );
#include <iostream>
#include <vector>
using namespace std;
//如果在main之后的定义成员函数,则在main之前先声明
void demo1(int a, int b);
void demo2(int &a, int &b);
void demo3(const vector<int> &a, vector<int> &b);
int main(){
int c = 3,d = 4;
demo1(c, d);
cout << "demo1后输出" << c << d << endl; //demo1后输出并发现值未变
int &a = c;
int &b = d;
demo2(a, b);
cout << "demo2后输出" << a << b << endl;
// vector的定义和初始化
vector<int> e;
e.reserve(10);
for(int i = 0; i < 10; i++)
{
e.push_back(i);
}
vector<int> f;
for( int j = 0; j < 10; j++ )
{
f.push_back(j);
}
const vector<int> &v1 = e; //常数引用,不可修改
vector<int> &v2 = f; //普通引用,可以修改
demo3(v1, v2);
cout << "demo3后输出" << v1[0] << v2[0] << endl;
}
void demo1(int a, int b){
a = a+1;
b = b+1;
cout << "demo1中输出" << a << b << endl;
}
void demo2(int &a, int &b){
a = a+1;
b = b+1;
cout << "demo2中输出" << a << b << endl;
}
void demo3(const vector<int> &a, vector<int> &b){
cout<<a[6]<<endl;
b[0] = a[6];
cout << "demo3中输出" << a[0] << b[0] << endl;
}