实例化数组的方法之间的区别
Difference between the methods of instantiating array
>假设在一个问题中,我们必须声明一个 n 大小的数组,其中1 <= n <= 1000000000
有两种(可以更多)方法可以做到这一点:
-
int arr[1000000001];
,可以根据输入根据需要处理空间。 -
可以先询问用户数组的大小,然后实例化数组:
辛>>;int arr[n];
我想知道这两种方法的优缺点是什么。
两种方法的区别在于:
第一种方法符合标准,而第二种方法不符合标准。C++标准不允许使用可变长度数组。编译器支持它们作为扩展,但严格意义上的用法不是可移植的。
第一种方法的风险在于,即使不需要,也可能耗尽堆栈空间或浪费内存。在这种情况下,最好的解决方案是使用 std::vector
.
相关文章:
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- int(c) 和 c-'0' 之间的区别。C++
- C++ 使用 assign 函数的字符串与直接使用 '=' 更改值的字符串之间的区别
- std::atomic和std::condition_variable wait,notify_*方法之间的区别
- 我是C++编程的新手,这些代码之间有什么区别,我应该使用哪一个
- 在 const 函数中通过引用和指针返回之间的区别
- 我想知道长双倍和双倍之间的区别
- 这 4 个 lambda 表达式之间有什么区别?
- 结构体 S { int align; } 之间的区别;(struct 关键字后的名称)和 struct { int al
- (double) 和 double() 之间的区别
- & 和 * 之间的区别
- std::is_convertible 和 std::convertible_to 之间的区别(在实践中)?
- 析构函数和'delete'之间的区别
- 在 typedef 内部使用 const 关键字和在 typedef 外部使用 const 关键字之间有区别吗?
- 从预序遍历构造 bst 的 c++ 和 python 解决方案之间的区别
- vector.back() 和 vector[vector.size() - 1] 之间的区别?
- 空指针常量 (nullptr)、空指针值和空成员指针值之间有什么区别?
- 函数签名与调用的函数不匹配,常量字符[]和字符*之间的区别?
- OpenMP #pragma omp for v/s #pragma omp parallel for 之间的区别?
- S() 与 S{} 之间的区别?