引用
什么是引用呢?
引用是变量的别名,是指向变量的常量指针。
#include<iostream>
using namespace std;
int main(void)
{
int i = 10;
int &r = i;
cout<<"i="<<i<<" "<<"r="<<r<<endl;
cout<<"&i= "<<&i<<" &r="<<&r<<endl;
// 通过修改i来修改i所代表的单元的值
i = 20;
cout<<"i="<<i<<" "<<"r="<<r<<endl;
cout<<"&i= "<<&i<<" &r="<<&r<<endl;
// 通过修改r来修改r所代表的单元的值
r = 30;
cout<<"i="<<i<<" "<<"r="<<r<<endl;
cout<<"&i= "<<&i<<" &r="<<&r<<endl;
return 0;
}
运行结果
可以看到第一次给引用变量r赋值为i时,r和i的值一样,且地址一样,说明r和i都指向了同一个单元。因此,在后面修改i的值时,r的值也会相应变化;同样修改r的值时,i的值也会相应变化。
如下图所示:i和r两个变量名指向同一块地址单元,这个内存地址单元的地址为0x70fe34。所以无论是修改变量i的值还是修改变量r的值都是修改内存地址0x70fe34中的值,所以,而当内存地址0x70fe34中的值发生变化时,变量i和r的值都会发生变化。
指针
#include<iostream>
#include<algorithm>
#include<math.h>
#include<string.h>
#include<iomanip>
#include<stack>
#include<stdio.h>
using namespace std;
void change_p0(int* p)
{
//修改指针P使它指向另一个整形变量b,这里创建了一个指针变量p的副本
int b = 333;
p = &b;
cout<<"change_p0:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
}
void change_p1(int* &p)
{
//修改指针P使它指向另一个整形变量c,在退出该函数后,p仍然指向整形变量c
int c = 4444;
p = &c;
cout<<"change_p1:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
}
int main()
{
// freopen("cin.txt","r",stdin);
int* p = NULL;
int a = 3;
p = &a;
// &p是指针变量P的地址,p是指针变量的值(指针变量p指向的变量的地址),*p是指针变量指向的变量的值
// change_p0函数内外的指针变量p的地址不同,说明在函数中产生了指针变量的拷贝
cout<<"before change_p0:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
change_p0(p);
cout<<"after change_p0:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
cout<<endl<<endl;
//change_p1函数内外指针变量的地址相同,说明在函数内外使用的指针变量是同一个变量
cout<<"before change_p1:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
change_p1(p);
cout<<"after change_p1:\t"<<&p<<"\tp:"<<p<<"\tp->data:"<<*p<<endl;
return 0;
}
执行结果:
从执行结果可以看出,在函数change_p0(int *p)中,形参指针p的地址0x72fe10,而传入的实参指针p的地址是0x72fe38,两个指针变量是不同的指针变量。也就是说,在传参过程中,新建了一个指针p(形参),且这个形参指针p和实参指针p的内容一样(即这两个指针变量都指向同一个变量a(=3))。然后我们在change_p0()中将形参指针重新指向了变量b(=333),但实参指针仍然指向变量a。
但在函数change_p1(int * &p)中使用的是传引用调用,实参指针p和形参指针p是同一个指针,因此,在函数change_p1将指针p指向变量c(=4444)之后,结束函数调用,返回main函数,实参指针p的值也发生了变化,指向了变量c。
指针小例子2
int a, b, c;
a = 1, b = 2, c =333;
int *arr[3]={&a, &b, &c};
int *num = arr[0];
int *p = num;
cout<<"&a: "<<&a<<endl;
cout<<"num: "<<(num)<<" &num:"<<&num<<endl;
cout<<"p:"<<p<<" &p: "<<&p<<endl;
cout<<(arr)<<" "<<(arr[0])<<endl;
运行结果