电子说
百度百科是这样解释的:C++是C语言的继承,它可进行过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行以继承和多态为特点的面向对象的程序设计。
引用(reference)就是C++对C语言的重要扩充。引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样,编译器不会为引用变量开辟内存空间,它和它引用的变量共用同一块内存空间。引用的声明方法:类型标识符 &引用名=目标变量名。
别名,又可以说是外号,代称,比如水浒传里几乎是别名最多的地方。林冲,在家称为"林教头",江湖上人称"豹子头"。教头和豹子头就是林冲的别名。
&就是引用,但是&这个操作符和取地址&操作符是重叠的,所以它们需要不同的场景规范:
当 &b单独存在时,这时就代表取地址,为取出变量的地址。
但是如果这样:
int main()
{
int a = 10;
int& b = a; // 引用
int* p = &b; // 取地址
return 0;
}
当 & 位于类型和变量名之间时,为引用。
调试查看一下 a 和 b 的关系:
我们发现a和b的值不仅相等,连它的地址也是相同的。这就可以说明,b就是a ,但是在语法层面上,这里b并不是开辟的新空间,而是对原来的a取了一个新名称,叫做b。
就好比林冲被叫做豹子头一样,林冲还是林冲,豹子头也是它;而a就是a,但是b也是 a 。
而如果这时候对 a 或 b 任意一个修改,那么 a 和 b 都会发生修改。
引用有以下3点是必须注意的!!!
引用是取别名,所以在定义的时候必须明确是谁的别名。
就和林冲一样,他可以叫豹子头也可以叫林教头,这都是它。
所以一个变量也可以有多个别名。
而对于一个起过别名的变量,对它的别名取别名也是可以的。
而从根本上看,就可以这么理解:
本质上还是一个变量。
但是别名不能和正式名字冲突,就比如取过别名,就不能定义和别名重名的变量,即使它们的类型并不相同。
所以说这里的报错信息并不准确,实际上是命名冲突。
int main()
{
int a = 10;
int& b = a;
int c = 20;
b = c;
return 0;
}
对于下一组代码,有什么含义?
这里的代码意思是第二个含义,就是赋值,我们调试看看:
调试我们也可以看到,我们只是把 c 的值赋值给了 b ,b 的地址还是没变的 ,并且 a 的值也改变了。
这就说明引用一旦引用某一个实体,就不能引用其他的实体,引用是不会发生改变的。
因为它们是完全独立的两个变量,仅有的关联也只是值相等,改变 b 并不能影响 c ,但是此时 b 是 a 的别名,所以改变 b 就会影响 a 。
图:
但是对于指针,则是截然不同的:
int main()
{
int a = 10;
int c = 20;
int* p = &a;
p = &c;
return 0;
}
对于指针来说,指针就可以时刻修改:
p原本指向 a ,现在指向 c.
但是引用也有局限性,因为引用之后的变量是不可修改引用的,比如链表,节点是要不断更替迭代的,所以还需要指针配合,C++才可以写出一个链表。
全部0条评论
快来发表一下你的评论吧 !