变量的引用

article/2025/9/14 16:23:30

引用是C++对C的一个重要扩充。

1、引用的概念:变量的引用就是变量的别名。引用不是新定义一个变量,而是给已存在变量取了一个别名,编译器不会为引用变量开辟内存空间,它和它引用的变量共用同一块内存空间。

 从上面图中就可以看出,b是a的别名,b和a共用同一个空间,并没有为b开辟新的空间。

2、对引用的简单使用:

#include<iostream>
using namespace std;
int main()
{int a = 10;int& b = a;a = a * a;cout << a <<" " << b << endl;b = b / 5;cout << a <<" " << b << endl;
}

    

 

分析:因为a与b共用同一块内存空间,所以当a变化时b也变化,当b变化时a也变化。

3、对引用的说明:
a、声明引用时必须指定它代表的是哪个变量,即对它初始化。

b、引用与其所代表的变量共享同一内存单元,系统并不为引用另外分配存储单元。

c、当&a前面有类型符如 int &a,它必然是对引用的声明。如果前面没有类型符如p=&a,此时的&时取地址运算符。

d、对引用的初始化可以是一个变量名,也可以是另一个引用。

int main()
{
int a = 3;
int& b = a;
int& c = b;
}

 e、引用在初始化后不能再重新声明为另一个变量的别名。

 4、将引用作为函数的参数:C++之所以增加引用,主要还是利用它作为函数的参数。

在C语言中,函数的参数传递主要是以下面两这种方式:

方式一:将变量名传给形参,传给形参是变量的值。如下边代码:此时的a、b都是作为入参,将a与b相加的结果通过函数的返回值返回。

#include<stdio.h>
int Add(int a, int b)
{return a + b;
}
int main()
{int a = 10;int b = 20;int res = Add(a, b);printf("%d\n", res);
}

方式二: 不通过函数的返回值返回,通过函数的参数返回,此时参数就要用指针的方式对其结果返回,这个参数就是出参。如下面代码:

#include<stdio.h>
void Add(int a, int b,int *returnRes)
{*returnRes=a + b;
}
int main()
{int a = 10;int b = 20;int res;Add(a, b, &res);printf("%d\n", res);
}

在第一种方式中我们通过返回a+b的结果给到res 因此我们会开辟一个无名的临时空间给res;

第二种方法中我们要给指针开辟空间,存放res的地址。这两种方式都要开辟一定的空间,程序效率不高,所以在C++中我们更倾向于用引用作为函数的参数。

#include<iostream>
using namespace std;
void Add(int a, int b,int &returnRes)
{returnRes=a + b;
}
int main()
{int a = 10;int b = 20;int res;Add(a, b, res);printf("%d\n", res);
}

在上面这个代码中是将引用作为函数的参数,returnRes时res的别名,没有为returnRes开辟新的空间,因此对returnRes进行操作就是对res直接操作,提高程序的效率。

5、对于引用的进一步说明:

a、不能建立void类型的引用。

void &a=9         //错误

b、不能建立引用的数组。

char a[2]={1,2};
char &b[2]=a      //错误

数组名a只能能代表数组首元素的地址,本身并不是一个占有存储空间的值。 

c、可以将变量引用的地址赋给一个指针,此时指针指向原来的变量。

int a=3;
int &b=a;
int *p=&b;//指针p指向变量a的引用b,相当于指向变量a

d、可以建立指针变量的引用。

 

int a=3;
int *p=&a;
int * &pt=p;//pt 是 p的别名,pt指向a

e、可以用const 对引用加一限定,不允许改变该引用的值。也称为常引用。

int a=3;
const int &b=a;//不允许改变该引用的值

 此时如果你想改变a的值就是错误的。常引用通常用作为函数的形参,因为有时希望保护形参的值不被改变。


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

相关文章

引用变量

引用就是一个变量的别名&#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…

C++之new动态分配内存生成数组

【任务1】&#xff1a; 编写并测试3*3矩阵转置函数&#xff0c;使用数组保存3*3矩阵。 实验要求 &#xff08;1&#xff09; 转置函数参数为二维数组&#xff1b; &#xff08;2&#xff09; 在main函数中实现输入、输出 #include <iostream> using namespace std…

C语言中的动态内存分配

大家好&#xff0c;今天简单讲一讲C语言中的动态内存分配。 补充&#xff1a;C程序中的内存块。 在C程序中&#xff0c;通常将内存划分为以下六个区域&#xff1a; &#xff08;1&#xff09;内核区域。这块区域是操作系统的&#xff0c;用户不能使用。 &#xff08;2&…

C语言动态分配内存

C语言动态分配内存 malloc 动态开辟内存的函数&#xff1a; void* malloc (size_t size); 这个函数向内存申请⼀块连续可⽤的空间&#xff0c;并返回指向这块空间的指针 如果开辟成功&#xff0c;则返回⼀个指向开辟好空间的指针 如果开辟失败&#xff0c;则返回⼀个NULL…

C/C++动态分配内存的几种方法

使用C/C编程时&#xff0c;会经常动态分配内存&#xff0c;以便合理使用内存&#xff0c;本文主要讲述动态内存分配的几种方法及一些原理&#xff0c;理解不深刻之处欢迎指教。 引言 为什么要进行动态内存分配&#xff1f;以数组为例&#xff0c;数组元素在内存中存储的地址是…

sadad

出版社&#xff1a; 河北少年儿童出版社 ISBN&#xff1a;12176804 版次&#xff1a;1 商品编码&#xff1a;12176804 包装&#xff1a;精装 丛书名&#xff1a; 幼儿家庭课堂 开本&#xff1a;12开 出版时间&#xff1a;2017-05-01 用纸&#xff1a;铜版纸 适读人群 &#xff…