从同一向量推入元素:安全措施
从同一向量推回元素的安全性取决于重新分配的可能性,这可能会使对现有向量元素的引用无效。这个问题出现在以下示例中:
<code class="cpp">vector<int> v; v.push_back(1); v.push_back(v[0]);</code>
如果第二次push_back触发重新分配,则对v[0]的引用将变得无效。为了解决这个问题,可以使用以下方法:
<code class="cpp">vector<int> v; v.push_back(1); v.reserve(v.size() + 1); v.push_back(v[0]);</code>
通过调用reserve,我们显式请求足够的内存,确保后续插入过程中不会发生重新分配。
根据C标准,push_back 相对于元素引用的行为并未明确定义为缺陷,尽管它可能会导致无效引用。这是因为标准要求 vector::insert 能够正常工作,即使插入改变了其他元素的位置。
以上是同一个向量推送元素时如何保证安全?的详细内容。更多信息请关注PHP中文网其他相关文章!