如何根据参数的大小在函数内声明数组
How can I declare an array inside a function according to the size of a parameter?
这是我尝试过的:
int fun1(vector<int> s)
{
const int n = s.size();
int arr[n]; //<----want to declare an array of length s.size()
}
但这告诉我 n 不是一个常量表达式,所以我不能用它来声明数组大小。但是如果我尝试:
int fun1(vector<int> s)
{
const int n = 10;
int arr[n]; //<-----this works
}
那就好了。即使我制作了 const 类型的向量 s,它仍然无法将大小识别为常量表达式。我该怎么做?
通过int arr[N];
声明数组的大小N
必须在编译时确定(某些编译器扩展除外,它也允许您在运行时定义它们)。顺便说一下,你可以做到:
std::unique_ptr<int[]> arr (new int [n]);
// ... or ...
std::vector<int> arr(n);
当你声明这样的数组时
int arr[n];
编译器将在堆栈上为其分配内存。在这种情况下,C++标准要求n
在编译时是已知的,即它必须是const
的。
问题的答案是在运行时从堆中获取内存,如下所示:
int* arr = new int[n];
在这种情况下,内存是在运行时分配的,因此在运行时之前不需要知道n
的值。如果使用此方法,请不要忘记在完成以下操作后释放内存:
delete [] arr;
但是,正如评论所表明的那样,使用std::vector<int>
几乎肯定是一种更好的方法。除非你有充分的理由不这样做,否则我会同意。
为此
,C++有std::vector<int>(n)
,它保留了传统C数组的大部分语义,但也增加了很多好处(动态分配是一个,调整大小是另一个,算法支持是另一个)。即使底层代码需要 C 数组,您仍然可以使用 vector 并将第一个元素的地址向下传递(它们保证是连续的)。
通常,std::vector
使用堆作为底层存储,因此一方面可以更好地防止堆栈溢出(双关语),另一方面,您的代码现在使用动态分配。
相关文章:
- Visual Studio中的函数声明和函数定义问题
- 为什么函数声明中允许 const?
- 如果 x.h 仅由函数声明组成,为什么有必要在 x 中包含 x.h.cpp
- * 和 ** 在 C++ 函数声明中是什么意思?
- 构造函数/函数声明参数列表中的统一初始化
- 在将函数声明为友元时,尖括号的含义是什么?
- 为什么转换函数声明不需要至少一个定义类型说明符
- 如何正确编写指针函数声明?
- 在"template"和函数声明之间使用:template<typename trait> using tr = base_trait<trait> void fn(tr::t
- 为什么要将函数声明和定义放在单独的文件中
- 为什么系统日志有两个不同的函数声明?
- 我如何获取数组的大小,以便我可以从函数声明所述数组
- 使用 enable_if 在按值传递与按引用传递之间更改函数声明
- JavaScript 中的一等函数和 C++ 中的函数声明
- C++ 通过函数声明后初始化向量
- VS2017 #error: : snprintf 的宏定义与标准库函数声明冲突
- C++ 17 个友元函数声明和内联命名空间
- MSVC 2017 - 错误 - 如何将模板类 X 的模板成员函数声明为嵌套类 X::Y 的好友
- 将派生类的构造函数声明为父类的友元
- 用于从 ANSI 字符串转换为 std::basic_string <TCHAR>的正确函数声明