c++ - 在 header 中声明和初始化 vector (还有其他 STL 容器)

标签 c++ stl header global-variables

现在我正在头文件中创建一个 vector 。请注意,我不只是宣布它。

std::vector<int> attacked_nodes = std::vector<int> ();

它工作正常,但它让我有些怀疑。这不在适当类的上下文中,它只是许多函数使用的变量。

我想知道这是不是

  • 正确(会适得其反吗?)
  • 可接受的做法(可能不是)

我搜索了一下,是的。

注意:这可能是一种糟糕的编码习惯,我明白了。我想知道它是否真的不正确

我不希望使用 new 来创建指针,也许我可以使用 new 并保存引用?这是still inelegant , 但可能有效。

谢谢。

最佳答案

它是有效的 C++,但不是好的设计。您正在头文件中定义一个全局对象。这有两个问题:“全局”位和“在头文件中”位。

让我们从头文件问题开始。 C++ 有一个称为单一定义规则的规则,其中一部分要求您在整个程序中不能对一个对象有多个定义。如果您将此头文件包含在多个实现文件中(请记住,这就像将头文件的内容复制并粘贴到您的源文件中),您将有多个定义,因此打破了一个定义规则。

现在全局状态的问题在于它隐藏了依赖关系。您提到您有许多使用此对象的函数,但从这些函数的调用站点来看它们使用该对象并不清楚。即使您使用完全相同的参数调用它们,您的函数也可能返回不同的结果,这仅仅是因为这个全局状态可能已经改变。这是糟糕的界面设计,使功能更难测试(和信任)。

关于c++ - 在 header 中声明和初始化 vector (还有其他 STL 容器),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28888134/

相关文章:

c++ - 性能 AVX/SSE 汇编与内部函数

STL - 获取STL vector 中大于某个值的元素的所有位置

c++ - std::stable_sort 与 std::sort

javascript - 当 3 列具有相同标题时,在 node.js 中使用 fast-csv 读取 csv

audio - MP4-读取音频 block

c++ - main() 的函数类型

c++ - 如何为CSR格式设置SparseMatrix.valuePtr()、SparseMatrix.outerIndexPtr()和SparseMatrix.innerIndexPtr()?

c++ - OpenCV 的 cvAcc() 有什么作用?

c++ - 设置priority_queue容器的好处

android - ListView 适配器的页眉和页脚