new 分配空间;引用

一、new

new 操作符是分配堆区内存空间的,delete释放

cpp 复制代码
// 开辟一个 int型 并初始化为100
int* type1()
{   
	int* p = new int(100);
	return p;
}

 // 开辟一个 整形数组
int* type2()
{
	int* arr = new int[10];
	for (int i = 0; i < 10; i++)
		arr[i] = i + 1;

	return arr;
}


int main()
{
	int* p = type1();
	cout << *p << endl;

	int* arr = type2();
	for (int i = 0; i < 10; i++)
		cout << arr[i] << ' ';

	// 释放 new开辟的内存
	delete p;
	p = NULL;

	delete[] arr;
	arr = NULL;

	return 0;
}

new 的返回值是开辟空间的地址

二、引用

1、基本使用: 类型 &别名=原名 ,对应同一地址

cpp 复制代码
int main()
{
	int a = 10;
	cout << "a前的值:" << a << endl;

	int& b = a;
	b = 20;

	cout << "a后的值:" << a << endl;
    cout << "b的值:" << b << endl;

// 10 20 20

	return 0;
}

二、注意事项

①、一定要初始化

②、引用后,不能改变

int a=10;

in c=100;

int &b =a; √

int &b; ×

int &b = c ; ×

三、引用做函数参数:

引用也是将同一地址给了出去

cpp 复制代码
// 指针接收
void Swap_1(int* a, int* b)
{
	int c = *a;
	*a = *b;
	*b = c;
}
// 引用
void Swap_2(int& a, int& b)
{
	int c = a;
	a = b;
	b = c;
}

int main()
{
	int a = 10;
	int b = 99;

	cout << "交换前:" << a <<' ' << b << endl;

	Swap_1(&a, &b);
	Swap_2(a, b);

	cout << "交换后:" << a<<' ' << b << endl;

	return 0;
}

得出的结果一样

四、引用做函数的返回值

cpp 复制代码
int& test()
{
    // 不能返回局部变量的引用、地址
	static int a = 10;
	return a;
}

int main()
{
	int& ret = test();
	cout << "ret = " << ret << endl;
	cout << "ret = " << ret << endl;

	test() = 999;
	//当 引用作为函数返回值,这个函数调用可以作为左值
	cout << "ret = " << ret << endl;
	cout << "ret = " << ret << endl;

	return 0;
}

五、引用的本质:

本质是 : 指针常量

cpp 复制代码
int main()
{
	int a = 10;

	// 本质 int* const ret = &a;
	int& ret = a;

	// 本质: *ret = 100;
	ret = 100;

	cout << a << ' ' << ret << endl;

	return 0;
}

本质是 :int* const ret = &a; 所以引用初始化后不能改变指的地方,但是可以改变值

🚗🚗 🚗 🚗 🚗 🚗 🚗 🚗

相关推荐
01二进制代码漫游日记5 分钟前
C/C++中的内存区域划分
c语言·jvm·数据结构·学习
一方热衷.13 分钟前
YOLO26-OBB ONNXruntime部署 python/C++
开发语言·c++·python
Qt程序员18 分钟前
基于 C++ 实现自定义字符串 string 类
linux·c++·容器·指针·内存管理·运算符重载
Ivanqhz20 分钟前
活跃范围重写(Live Range Rewriting)
开发语言·c++·后端·算法·rust
xiaoye-duck25 分钟前
《算法题讲解指南:优选算法-链表》--51.两数相加,52.两两交换链表中的节点
数据结构·算法·链表
代码改善世界36 分钟前
【数据结构】八大排序算法详解(C语言实现)|插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序
c语言·数据结构·排序算法
2501_940315261 小时前
98验证二叉搜索树
java·数据结构·算法
ouliten1 小时前
C++笔记:std::numeric_limits
c++·笔记
承渊政道1 小时前
C++学习之旅【C++伸展树介绍以及红黑树的实现】
开发语言·c++·笔记·b树·学习·visual studio
郭涤生1 小时前
C++中设置函数与回调函数设值的性能差异及示例
开发语言·c++