数组初始化有多种方式,包括逐个赋值、部分初始化、全零初始化和自动推导大小;数组名本质是指向首元素的指针,支持指针运算和遍历;动态数组通过new创建并用指针管理,需delete[]释放;注意sizeof差异、函数传参时需传长度、避免返回局部数组指针,以防止越界和内存泄漏。

在C++中,数组和指针的配合使用非常常见,理解它们之间的关系以及如何正确初始化数组,对编写高效、安全的代码至关重要。掌握这些技巧能帮助你避免内存错误,提升程序稳定性。
数组的几种初始化方式
数组可以在定义时通过多种方式进行初始化,不同的方式适用于不同场景。
- 逐个赋值:int arr[5] = {1, 2, 3, 4, 5}; 这种方式明确指定每个元素的值。
- 部分初始化:int arr[5] = {1, 2}; 剩余元素自动初始化为0。
- 全零初始化:int arr[5] = {0}; 所有元素都被设为0,常用于清空数组。
- 自动推导大小:int arr[] = {1, 2, 3}; 编译器根据初始值数量确定数组长度。
指针与数组的天然联系
数组名本质上是一个指向首元素的指针,这使得指针可以自然地操作数组。
- int arr[5] = {10, 20, 30, 40, 50}; int* p = arr; 此时p指向arr[0],*p等于10。
- 通过指针遍历数组:使用p++可依次访问每个元素,注意不要越界。
- 指针运算:*(arr + i) 等价于 arr[i],这是数组下标操作的底层实现原理。
动态数组与指针配合
使用new关键字可在堆上创建动态数组,需用指针管理。
立即学习“C++免费学习笔记(深入)”;
- int* ptr = new int[10]; 分配10个int空间,ptr指向首地址。
- 初始化动态数组:可用循环赋值,或C++11后的{}语法(如new int[3]{1,2,3})。
- 必须配对使用delete[]释放内存:delete[] ptr; 避免内存泄漏。
常见陷阱与建议
数组和指针结合使用时容易出错,需特别注意以下几点。
- 数组名不是真正的指针:sizeof(arr) 返回整个数组字节数,而sizeof(ptr)返回指针大小。
- 传递数组给函数时,实际传的是指针,需额外传长度以防止越界。
- 不要返回局部数组的指针:函数结束后栈内存被回收,会导致悬空指针。
基本上就这些。理解数组初始化方式和指针的关系,能让你更灵活地处理数据。关键是清楚内存布局,避免越界和泄漏。不复杂但容易忽略细节。








