will stl deque reallocate my elements (c++)?

前端 未结 2 1200
旧巷少年郎
旧巷少年郎 2021-01-04 22:22

Hi I need an stl container which can be indexed like a vector but does not move old elements in the memory like a vector would do with resize or reserve (Unless I call reser

相关标签:
2条回答
  • 2021-01-04 23:03

    A careful reading of the documentation seems to indicate that so long as you insert at the beginning or the end it will not invalidate pointers, and invalidating pointers is a sign that the data is being copied or moved.

    The way it's constructed is not quite like a linked list, where each element is allocated individually, but as a set of linked arrays presumably for performance reasons. Altering the order of elements in the middle will necessitate moving data around.

    0 讨论(0)
  • 2021-01-04 23:25

    std::deque "never invalidates pointers or references to the rest of the elements" when adding or removing elements at its back or front, so yes, when you only push_back the elements stay in place.

    0 讨论(0)
提交回复
热议问题