· 引用就是一个指针的操作,只不过它是一个非常安全、被限制了的指针。
指针是指针,引用是引用,概念仍是不同的。只不过在编译器内部变量的引用存放的数据是一个地址。
int v1 = 10;
int* v2 = &v1;
int& v3 = v1; //v3实际保存的就是v1的地址
· 引用占内存!
为什么会有引用不占内存的说法? 因为打印变量和其引用的地址时输出相同,编译器误导了人这样认为。在实际中,编译器并不会取引用的地址,而是取引用的值(即对应的变量的地址),所以 打印出来的两个地址一样。许多书中关于引用的说法是错的,因为他们只看到了语法,而没有深入实质(汇编)地去了解。
· 引用和指针的区别
引用必须初始化,指针可以不初始化
指针在32位4字节,64位8字节。引用的大小与CPU的位数无关,与被引用的数据类型有关。
int v1 = 3;
int& v2 = v1; //v2的大小与v1的数据类型相关,此时为4个字节
指针可以存储new出来的内存空间的首地址,但引用不可以
int* v1 = new int; //正确
int& v2 = new int; //错误
void _tmain()
{
//引用v5实际上存储的是v1的地址,所以引用本质上是一个特殊的指针。但引用必须初始化且不可更改绑定的引用关系,引用大小与被引用的数据类型有关。
int v1 = 10;
int* v2 = &v1;
int v3 = v1;
int v4 = *v2;
int& v5 = v1;
/***************************************************************************
int v1 = 10;
0057195F C7 45 F4 0A 00 00 00 mov dword ptr [v1],0Ah
int* v2 = &v1;
00571966 8D 45 F4 lea eax,[v1]
00571969 89 45 E8 mov dword ptr [v2],eax
int v3 = v1;
0057196C 8B 45 F4 mov eax,dword ptr [v1]
0057196F 89 45 DC mov dword ptr [v3],eax
int v4 = *v2;
00571972 8B 45 E8 mov eax,dword ptr [v2]
00571975 8B 08 mov ecx,dword ptr [eax]
00571977 89 4D D0 mov dword ptr [v4],ecx
int& v5 = v1;
0057197A 8D 45 F4 lea eax,[v1]
0057197D 89 45 C4 mov dword ptr [v5],eax
**************************************************************************/
//引用占内存! 因为打印变量和其引用的地址时输出的地址相同,编译器误导了人认为引用不占内存。
_tprintf(_T("%p\r\n"), &v1);
_tprintf(_T("%p\r\n"), &v5);
_tprintf(_T("Input AnyKey To Exit\r\n"));
system("pause");
}