C++中引用变量详解

article/2025/9/14 21:17:10

目录

一、什么是引用?

二、引用的注意事项

三、引用的本质

四、常量引用

五、引用的使用场景​​​​​​​

六、引用和指针的区别


一、什么是引用?

引用实际上是给一个变量起别名,编译器不会为引用变量开辟一个新的内存空间,变量和它的引用变量共用同一块内存空间。就好比水浒传中的李逵有的别名,既可以叫做黑旋风,也可以叫铁牛,实际上都是同一个人。

语法:数据类型& 别名=原名

int main()
{int a = 10;int& b = a;//b是a的别名cout << "a=" << a << endl;//两者打印的结果是一样的cout << "b=" << b << endl;cout << "a的地址" << &a << endl;//两者地址是一样的cout << "b的地址" << &b << endl;return 0;
}

二、引用的注意事项

1、引用必须初始化

2、一个变量有多个引用

3、引用在初始化后,不可以改变其指向

int main()
{//1、引用必须初始化//int& a;//2. 一个变量可以有多个引用//int a = 10;//int& b = a;//int& c = a;//3、引用在初始化后,不可以改变其指向//int a = 20;//int b = 10;//int& c = a;//一旦初始化后,就不能修改//c = b;//赋值操作return 0;
}

三、引用的本质

引用本质就是一个指针常量,引用一旦初始化,其指向就不可以发生改变。

int main()
{int a = 10;//自定转化为int* const b=&a;//指针常量是指针的指向不可以改//也就说明了引用为什么不可以改int& b = a;//编译器发现b是引用,自动帮我们转化为*b=20;b = 20;
}

四、常量引用

当函数参数是引用的时候,有时需要用到常量引用,涉及到权限以及防止误操作。

权限方面不能放大,只能缩小。

例如一个变量是一个可读可写的权限,可以修改为只读的权限。

一个变量是只读的权限,不能修改为可读可写的权限。

int main()
{//权限平移int a = 10;int& b = a;//权限不能放大const int c = 20;//c是只读//int& d=c;//d是可读可写 c是只读,错误const int& d = c;//d是只读 权限平移//权限可以缩小int e = 30;//e可读可写const int& f = e;//f只读return 0;
}

如果使用引用传参,函数内如果不改变参数,建议使用const引用传参

例如一个函数实现打印的功能,使用引用传参,目的是为了打印,而函数内部依然可以改变形参,可能会涉及到误操作,可以加const修饰形参,防止形参改变实参。

//利用常量引用防止误操作修改实参
void ShowValue(const int& b)
{//b+=10;//误操作,改变了实参// 加入const之后,都是只读的权限,避免通过引用修改实参cout << b << endl;
}
int main()
{int a = 10;//该函数只是实现打印数据功能ShowValue(a);return 0;
}

五、引用的使用场景

1、引用做参数

作用:函数传参时,可以利用引用让形参修饰实参

优点:可以简化指针修改实参

总结:通过引用参数产生的效果同按地址传递是一样的,引用的语法更简单清楚

//引用做函数参数
void mySwap(int& a, int& b)
{int tmp = a;a = b;b = tmp;
}
int main()
{int a = 10;int b = 20;cout << "交换前a=" << a << endl;cout << "交换前b=" << b << endl;mySwap(a, b);cout << "交换后a=" << a << endl;cout << "交换后b=" << b << endl;return 0;
}
//交换前a=10 b=20
//交换后a=20 b=10

2、引用做返回值

作用:引用是可以作为函数的返回值的

注意:不能返回局部变量引用,可以返回静态变量引用

原因:局部变量是存放在栈区的,出了作用域便会销毁,而静态变量是存放在静态区的,

静态区上的数据在程序结束后系统释放

//这个程序使用引用返回本质是不对的,返回值没有保障
int& count()
{int n = 0;//n存放在栈区,出了作用域就被销毁n++;return n;
}
int main()
{int& ret = count();cout << ret << endl;cout << ret << endl;return 0;
}
//这个场景可以使用传引用返回
int& count()
{static int n = 0;//static修饰的变量n存放在静态区n++;return n;
}
int main()
{int& ret = count();cout << ret << endl;cout << ret << endl;return 0;
}

六、引用和指针的区别

语法角度:引用是没有开空间的,指针有开空间

int main()
{int a = 10;//语法角度,ra没有开空间int& ra = a;ra = 20;//语法角度,pa开了4or8byte空间int* pa =&a;*pa = 20;return 0;
}

底层角度:引用和指针都是开了空间的

 引用和指针的不同点:

1. 引用概念上定义一个变量的别名,指针存储一个变量地址。
2. 引用在定义时必须初始化,指针没有要求
3. 引用在初始化时引用一个实体后,就不能再引用其他实体,而指针可以在任何时候指向任何一个同类型实体
4. 没有NULL引用,但有NULL指针
5. 在sizeof中含义不同:引用结果为引用类型的大小,但指针始终是地址空间所占字节个数(32位平台下占4个字节)
6. 引用自加即引用的实体增加1,指针自加即指针向后偏移一个类型的大小
7. 有多级指针,但是没有多级引用
8. 访问实体方式不同,指针需要显式解引用,引用编译器自己处理
9. 指针使用更强大,更危险,更复杂,引用比指针使用起来相对更安全,更简单,但相对局限

 


http://chatgpt.dhexx.cn/article/O0hxLxfc.shtml

相关文章

C++变量引用

本篇介绍的变量引用与之前介绍的指针不是同一概念&#xff0c;它们有本质的区分&#xff1a; 1&#xff09;不存在空引用。引用必须连接到一块合法的内存。 2&#xff09;一旦引用被初始化为一个对象&#xff0c;就不能被指向到另一个对象。指针可以在任何时候指向到另一个对…

Java_引用变量

目录 1.认识 null ​编辑 2.数组的应用 3.数组作为函数的参数 4.数组作为函数的返回值 5.数组练习 数组转字符串 6.数组拷贝 (1)通过函数Arrays.copyOf()进行拷贝&#xff1a; (2)通过函数System.arraycopy()进行拷贝&#xff1a; (3)拷贝范围Arrays.copyOfRange() (4)比…

C++中的引用变量详解

文章目录 声明及定义代码引用变量的特点图片解释引用变量的本质引用变量的用途int & 和 const int & 的区别引用变量和宏定义&#xff08;#define&#xff09;的区别 声明及定义 [const] int& 变量名 右值 注意&#xff1a;[]内的是可选的。即这里的const限定词是…

引用变量及其作用

首先&#xff0c;先来明白一下什么是引用变量。 一个变量可以声明为一个引用&#xff0c;它起着该变量的别名的作用。对引用进行操作&#xff0c;实际上就是对被引用的变量进行操作。 引用运算符&#xff1a;&&#xff1b; 定义的一般形式&#xff1a;数据类型 &引用变…

变量的引用

引用是C对C的一个重要扩充。 1、引用的概念&#xff1a;变量的引用就是变量的别名。引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;它和它引用的变量共用同一块内存空间。 从上面图中就可以看出&a…

引用变量

引用就是一个变量的别名&#xff0c;声明&#xff1a; int a 0; int &b a; b就是a的引用&#xff0c;a和b指向的内存时同一个地址&#xff0c;b可以修改变量的值 一。主要的用途是将引用变量作为函数的参数传递&#xff0c;为什么呢&#xff1f; &#xff08;1&…

C++入门基础—— 引用变量

目录 什么是引用&#xff1a; 引用的例子 引用的特性&#xff1a; 常量引用与非常量引用 使用场景 引用与指针的区别 什么是引用&#xff1a; 引用的概念 引用实际上就是取别名&#xff0c;提起这个名字就会让人知道是谁&#xff0c;谈起“鸡哥”就知道是坤坤&#xff0c;…

C++——引用变量

目录 一、创建引用变量 二、将引用作为函数参数 三、引用的属性和特别处 四、临时变量、引用参数和const 五、返回引用 六、何使用引用参数 七、参考书籍 引用变量是C新增的一种复合类型。引用是已定义的变量的别名&#xff08;另一个名字&#xff0c;但两个名字都是表示…

014 变量的引用

目标&#xff1a; 1、变量的引用 2、可变和不可变量类型 3、局部变量和全局变量 一、变量的引用 。变量 和 数据 都是保存在 内存 中的 。在 python 中 函数 的 参数传递 以及 返回值 都是靠 引用 传递的 1.1 引用的概念 在 Python 中 。变量 和 数据 是分开存储的 。数据 保…

C语言动态内存分配函数

目录 1.malloc()2.free()3.calloc()4.realloc()5.小结 在C中我们开辟内存空间有两种方式 :1.静态开辟内存 : 例如: int a; int b[10]; 这种开辟内存空间的特点是 所开辟的内存是在栈中开辟的固定大小的 ,如a是4字节 ,数组b是40字节 ,并且数组在申明时必须指定其长度 , 如果是全…

【C语言】------ 动态内存分配

动态内存开辟详解 动态内存分配什么是动态内存分配&#xff1f; 一、为什么使用动态内存分配呢&#xff1f;二、动态内存函数1.malloc和free2.calloc和realloc 三、常见的动态内存错误1.对NULL指针的解引用操作2.对动态内存开辟的越界访问3.向free传递一个非malloc函数返回的指…

【C语言】为什么存在动态内存分配

文章目录 前言一、动态内存分配定义 二、动态内存分配的意义1.可以控制所开辟的内存大小2.可以多次利用这部分空间 三&#xff0c;动态内存函数的介绍 前言 提示&#xff1a;我们先来看一个在vs编译器下&#xff0c;同学们常犯的错误 注意&#xff1a;在VS编译器下C语言是不支…

静态内存分配与动态内存分配

静态内存分配与动态内存分配 动机 平时看c/c的书籍时&#xff0c;总会看到一种观点&#xff0c;说是C/C语言使用的时候动态内存分配是最重要的&#xff0c;使用malloc等函数分配的内存必须要释放&#xff0c;否则及其容易出现内存泄露。但是自己有时候挺奇怪的&#xff0c;啥…

JVM内存分配机制

Java虚拟机最重要的工作就是如何给对象分配内存空间&#xff0c;以及通过GC如何回收已经不再使用的内存空间。这篇文章主要介绍JVM中的Java对象是创建过程、对象内存的分配机制以及对象内存的回收机制。 一、对象的创建 在前面的文章《JVM类加载机制》中讲过&#xff0c;JVM中…

C语言动态内存分配详解

文章目录 前言一、为什么存在动态内存分配1、已掌握的内存开辟方式2、上述开辟空间方式的特点3、为什么存在动态内存分配 二、动态内存函数的介绍1、malloc2、free3、calloc4、realloc 三、常见的动态内存错误1、对NULL指针的解引用操作2、对动态开辟内存的越界访问3、对非动态…

动态内存管理(内存的分配与回收)详解

** 1. 数据结构之动态内存管理机制 ** 通过前面的学习&#xff0c;介绍很多具体的数据结构的存储以及遍历的方式&#xff0c;过程中只是很表面地介绍了数据的存储&#xff0c;而没有涉及到更底层的有关的存储空间的分配与回收&#xff0c;从本节开始将做更深入地介绍。 在使…

关于C++的动态内存分配

为什么要使用动态内存分配&#xff1f; 比较常见的情况是当我们使用一个数组时&#xff0c;我们需要去声明它&#xff0c;同时我们还需要提供给它一个编译时常量用于指定数组的长度。但是&#xff0c;我们有时候需要的数组并不是定长的。例如&#xff0c;我们要存储一个班级所…

【C语言】动态内存的分配

目录 &#x1f34b;&#x1f34b;前言 &#x1f34b;&#x1f34b;动态内存分配的定义 &#x1f34b;&#x1f34b;动态内存的优势 &#x1f34b;&#x1f34b;<1> 可以控制内存的大小 &#x1f34b;&#x1f34b;<2> 可以多次利用这部分空间 &#x1f34b;…

动态内存分配函数

一、静态存储分配与动态存储分配&#xff1a; &#xff08;1&#xff09;静态存储分配 通常定义变量&#xff08;或对象&#xff09;&#xff0c;编译器在编译时都可以根据该变量&#xff08;或对象&#xff09;的类型知道所需内存空间的大小&#xff0c;从而系统在适当的时候…

内存动态分区分配算法

文章目录 动态分区分配1. 首次适应算法&#xff08;First Fit&#xff09;2. 邻近适应算法&#xff08;Next Fit&#xff09;3. 最佳适应算法&#xff08;Best Fit&#xff09;4. 最坏适应算法&#xff08;Next Fit&#xff09; 总结 动态分区分配 所谓动态分区分配&#xff0…