加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 06:04:01 所属栏目:百科 来源:网络整理
导读:我需要一个固定大小的元素数组,并调用它们需要知道它们如何放入内存的函数,特别是: 像glVertexPointer这样的函数,需要知道顶点在哪里,它们距离另一个是多远,等等.在我的情况下,顶点将是要存储的元素的成员. 要获取这个数组中的一个元素的索引,我宁愿避免在
我需要一个固定大小的元素数组,并调用它们需要知道它们如何放入内存的函数,特别是:

>像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风格的阵列相比,可以有一个小的表现,比如由于矢量实现的索引验证.在大多数情况下,性能是由别的决定的,所以我不用担心,直到实际测量的性能表明这是一个真正的问题.

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读