我正在学习 C++。我们需要大数组。我想了解初始化和删除是否有区别(速度更重要,但没有问题也很重要):
int sequence[1000000];
和
std::array<int, 1000000> sequence;
还是根本没有区别?
更新 1
事实证明堆栈没有问题,我必须这样做:
auto sequence = std::make_unique<int[]>(1000000);
然后数组会在动态内存中创建吗?
我正在学习 C++。我们需要大数组。我想了解初始化和删除是否有区别(速度更重要,但没有问题也很重要):
int sequence[1000000];
和
std::array<int, 1000000> sequence;
还是根本没有区别?
更新 1
事实证明堆栈没有问题,我必须这样做:
auto sequence = std::make_unique<int[]>(1000000);
然后数组会在动态内存中创建吗?
您的两个选项都会创建一个包含 1000000 个元素的常规数组(指针),例如
int但是,它们是在堆栈上进行的,即特定函数的临时内存。如果您不仅需要创建这些数据,还需要处理它,并且很可能在几个函数中,那么使用动态内存(堆)会更明智
要在动态内存中创建数组,请使用新构造或更好的 STL:
这样的“数组”会将您的所有内容存储
int在动态内存中,但变量本身将在您创建它的地方创建。如果 this 在函数中,当函数退出(超出范围)时,变量及其所有内容将自动销毁。选项:一个全局变量,一个全局类的字段,或者拖一个指针指向这个通过到处创建的变量new,这取决于你的项目是如何设计的如果您对速度感兴趣,您可以通过立即调用resize (N)你事先知道的数组的
您可以使用std::vector[]以与使用常规数组相同的方式使用向量:
如果速度对您来说极其重要,动态内存可以更简单地使用:
简单地使用指针并不会带来显着的时间增益,但这并不是事实,但 std::vector 包装器最终会做到这一点 + 某种包装器和额外的检查。但是,在这种情况下,您必须注意内容和占用的内存。但是您是C程序员,您很强大,可以处理)除了我们之外还有谁..)