C:使用std :: vector可以安全地像数组一样吗?

我需要一个固定大小的元素数组,并调用它们需要知道它们如何放入内存的函数,特别是:

>像glVertexPointer这样的函数,需要知道顶点在哪里,它们距离另一个是多远,等等.在我的情况下,顶点将是要存储的元素的成员.
>要获取这个数组中的一个元素的索引,我宁愿避免在我的元素中有一个索引字段,但是宁愿玩指针算术(即:Element * x的索引将是x – & array [0 ]) – btw,这对我来说听起来很脏:是好习惯还是应该做别的事情?

使用std :: vector可以安全吗?

有些东西让我觉得std :: array更合适,但是

>我的架构的构造函数和析构函数很少被称为:我不介意这样的开销.
>我要将std :: vector的容量设置为我需要的大小(用于std :: array的大小,因此不会因为零星重新分配而占用开销.
>我不介意std :: vector的内部结构有一点空间开销.
>我可以使用这个能力来调整向量的大小(或者更好的是:在设置过程中选择一个大小),我认为没有办法用std :: array做这个,因为它的大小是一个模板参数(太糟糕了:我可以使用一个旧的C-like数组,只是在堆上动态分配它).

如果std :: vector对我的目的很好,我想知道细节,如果它将有一些关于std :: array(或一个普通的C数组)的运行时开销:

我知道,一旦增加了它的大小,它就会调用任何元素的认构造函数(但是,如果我的数据有一个空的认构造函数,我猜这不会花费任何东西),对于析构函数来说也是如此.还要别的吗?

解决方法

向量保证所有元素都具有连续的内存,因此可以安全地在您的方案中使用.与c风格的阵列相比,可以有一个小的表现,比如由于矢量实现的索引验证.在大多数情况下,性能是由别的决定的,所以我不用担心,直到实际测量的性能表明这是一个真正的问题.

如其他人所指出的那样,如果您使用指向元素(或迭代器)的指针来访问它时,请确保在使用存储在其中的数据时不重新分配向量.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...