传值调用
是默认的参数传递机制,实参会复制给形参,调用的语义是每次取得实参的副本并将该复本用作形参,即会有复本的开销,并且不改变实参的值。 适用于:传值调用用于不应该被函数改变的小型对象。
例子: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; }