segmentation fault 11 in C++ on Mac(Mac 上 C++ 中的分段错误 11)
问题描述
当我尝试运行时
int N=10000000;
short res[N];
我得到分段错误 11
当我换成
int N=1000000;
short res[N];
效果很好
推荐答案
您已超出操作系统提供的堆栈空间.如果需要更多内存,最简单的方法是动态分配:
You've exceeded your stack space given by the OS. If you need more memory, the easiest way is to allocate it dynamically:
int N=1000000;
short* res = new short[N];
但是,在这种情况下,std::vector
是首选,因为上述要求您手动释放
内存.
However, std::vector
is preferred in this context, because the above requires you to free
the memory by hand.
int N = 1000000;
std::vector<short> res (N);
如果你可以使用 C++11,你也可以通过使用 unique_ptr
数组特化来节省一些时间:
If you can use C++11, you can possibly save some fraction of time by using unique_ptr
array specialization, too:
std::unique_ptr<short[]> res (new short[N]);
由于重载了 operator[]
,上述两个自动方法仍然可以与熟悉的 res[index]
语法一起使用,但要获取内存操作的原始指针你需要 res.data()
和 vector
或 res.get()
和 unique_ptr
.
Both of the automatic methods above can still be used with familiar res[index]
syntax thanks to overloaded operator[]
, but to get the raw pointer for memory operations you'd need res.data()
with vector
or res.get()
with unique_ptr
.
这篇关于Mac 上 C++ 中的分段错误 11的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Mac 上 C++ 中的分段错误 11


- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01
- Stroustrup 的 Simple_window.h 2022-01-01
- 从python回调到c++的选项 2022-11-16
- C++ 协变模板 2021-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- 静态初始化顺序失败 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- 近似搜索的工作原理 2021-01-01