C++中函数不能直接返回局部数组,但可通过std::array(固定大小)、std::vector(动态大小)或智能指针如std::unique_ptr管理堆数组来安全返回;避免返回指向栈内存的指针,以防未定义行为。

在C++中,函数不能直接返回一个局部数组,因为数组在函数结束时会被销毁。但可以通过几种安全的方式来实现“返回数组”的效果。以下是几种推荐做法。
使用std::array(固定大小数组)
如果数组大小在编译时已知,std::array 是最简单且安全的选择。它封装了C风格数组,支持拷贝和返回。
示例代码:
#include int main() {
#include iostream>
std::array
std::array
return arr;
}
auto result = getArray();
for (int val : result) {
std::cout
}
return 0;
}
使用std::vector(动态大小数组)
当数组大小在运行时确定,或需要动态调整时,std::vector 是最佳选择。它可以安全地从函数返回,内部自动管理内存。
示例代码:
#include std::vector int main() {
#include
std::vector
return vec;
}
auto result = getVector();
for (int val : result) {
std::cout
}
return 0;
}
通过指针返回堆上分配的数组(谨慎使用)
可以使用 new 在堆上创建数组并返回指针,但必须确保调用者负责释放内存,否则会造成泄漏。
立即学习“C++免费学习笔记(深入)”;
更安全的做法是返回 std::unique_ptr 或 std::shared_ptr 来自动管理生命周期。
示例:返回 unique_ptr 管理的数组
#include std::unique_ptr int main() {
#include
auto arr = std::make_unique
for (int i = 0; i
arr[i] = i * 10;
}
return arr;
}
auto ptr = getDynamicArray();
for (int i = 0; i
std::cout
}
return 0;
}
避免返回局部数组指针
以下写法是错误且危险的:
int* badFunction() {
int arr[5] = {1, 2, 3, 4, 5};
return arr; // 错误:arr 在函数结束后被销毁
}
访问返回的指针会导致未定义行为。
基本上就这些。优先使用 std::array 或 std::vector,它们既安全又高效。涉及堆内存时,配合智能指针使用能有效避免资源泄漏。不复杂但容易忽略的是别让函数返回指向栈内存的指针。









