Bootstrap

C语言中的引用

· 引用就是一个指针的操作,只不过它是一个非常安全、被限制了的指针。
指针是指针,引用是引用,概念仍是不同的。只不过在编译器内部变量的引用存放的数据是一个地址。
    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");
}
;