引用&
c++里能用引用的就不用指针;引用实际上就是一个别名,一旦初始化就不会在引用其他变量。除了作为变量,定义后必须初始化。
void show(const int &rint);//只读;
void show(int &rint);//可读写
- 引用的本质
引用实质上是变量名的别名,是用指针实现的。
double a = 3.14;
double &b = a;
cout<<sizeof(b)<<endl;//4
- 左值引用int &data/右值引用int &&data
int a[]{
1,2,3,4,5};
int *p(a);
//int & * lp(&a);
int * & lp(p); // &取地址 左值引用, `int * &`指针的引用类型
lp+=1;
cout<<*lp<<endl; // *取值
// X int * && rp(p+2); //&& 右值引用, 不能赋指针 X
int * && rp(&a[1]);// && 右值引用 赋&取地址 快速备份,自动回收 右值引用
rp += 3;
cout<<*rp<<endl; // *取值
move(左值)
变右值
void showit(int && a){
cout<<a<<endl;
}
int a[5]{
1,2,3,4,5};
//showit(a[3]);传参问题
showit(move(a[3]));
showit(a[3]+2);
- forward()完美转发
完美转发实现了参数在传递过程中保持其值属性的功能,即若是左值,则传递之后仍然是左值,若是右值,则传递之后仍然是右值。 - move()\forward()异同
std::move执行到右值的无条件转换。就其本身而言,没有move任何东西。
std::forward只有在它的参数绑定到一个右值上的时候,才转换它的参数到一个右值。
std::move和std::forward只不过就是执行类型转换的两个函数;std::move没有move任何东西,std::forward没有转发任何东西。在运行期,它们没有做任何事情。它们没有产生需要执行的代码,一byte都没有。
std::forward()不仅可以保持左值或者右值不变,同时还可以保持const、Lreference、Rreference、validate等属性不变;
引用一个数组
//二维数组
int b[2][3]{
1,2,3,4,5,6};
//引用二维数组 int(&rb)[2][3] = b;
int (&rb)[2][3](b);
//二维数组,每一个元素是一个指针。二维指针数组
int *pb[2][3]{
&b[0][0], &b[0