<legend id='KJD0z'><style id='KJD0z'><dir id='KJD0z'><q id='KJD0z'></q></dir></style></legend>

    1. <small id='KJD0z'></small><noframes id='KJD0z'>

        <tfoot id='KJD0z'></tfoot>

        <i id='KJD0z'><tr id='KJD0z'><dt id='KJD0z'><q id='KJD0z'><span id='KJD0z'><b id='KJD0z'><form id='KJD0z'><ins id='KJD0z'></ins><ul id='KJD0z'></ul><sub id='KJD0z'></sub></form><legend id='KJD0z'></legend><bdo id='KJD0z'><pre id='KJD0z'><center id='KJD0z'></center></pre></bdo></b><th id='KJD0z'></th></span></q></dt></tr></i><div id='KJD0z'><tfoot id='KJD0z'></tfoot><dl id='KJD0z'><fieldset id='KJD0z'></fieldset></dl></div>

        • <bdo id='KJD0z'></bdo><ul id='KJD0z'></ul>

        为什么我得到“向量迭代器不兼容"?

        Why am I getting quot;vector iterators incompatiblequot;?(为什么我得到“向量迭代器不兼容?)
        <i id='RtIKa'><tr id='RtIKa'><dt id='RtIKa'><q id='RtIKa'><span id='RtIKa'><b id='RtIKa'><form id='RtIKa'><ins id='RtIKa'></ins><ul id='RtIKa'></ul><sub id='RtIKa'></sub></form><legend id='RtIKa'></legend><bdo id='RtIKa'><pre id='RtIKa'><center id='RtIKa'></center></pre></bdo></b><th id='RtIKa'></th></span></q></dt></tr></i><div id='RtIKa'><tfoot id='RtIKa'></tfoot><dl id='RtIKa'><fieldset id='RtIKa'></fieldset></dl></div>

          <small id='RtIKa'></small><noframes id='RtIKa'>

        • <tfoot id='RtIKa'></tfoot>
        • <legend id='RtIKa'><style id='RtIKa'><dir id='RtIKa'><q id='RtIKa'></q></dir></style></legend>
              <tbody id='RtIKa'></tbody>

                  <bdo id='RtIKa'></bdo><ul id='RtIKa'></ul>
                • 本文介绍了为什么我得到“向量迭代器不兼容"?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  为什么这个代码

                  #include <algorithm>
                  #include <iterator>
                  #include <vector>
                  
                  int main()
                  {
                      std::vector<int> v;
                      v.push_back(1);
                      v.push_back(2);
                      v.push_back(3);
                      v.reserve(v.size() * 2);  // Reserve enough space to keep iterators valid
                      std::copy(v.begin(), v.end(), std::back_inserter(v));
                      return 0;
                  }
                  

                  给我调试断言失败,表达式:向量迭代器不兼容(Visual C++ 2008)?

                  give me the debug assertion failure, Expression: vector iterators incompatible (Visual C++ 2008)?

                  推荐答案

                  只有当向量必须重新分配时,对应于元素的迭代器才会失效,reserve 避免了这种情况.

                  Iterators corresponding to elements are only invalidated when the vector has to be reallocated, which reserve avoids.

                  然而,v.end() 不会保持有效.

                  However, v.end() won't stay valid.

                  标准对push_backinsert 的描述保证

                  The Standard's description of push_back and insert guarantees that

                  如果新容量大于旧容量,则导致重新分配.如果没有重新分配发生,插入点之前的所有迭代器和引用都保持有效.

                  Causes reallocation if the new size is greater than the old capacity. If no reallocation happens, all the iterators and references before the insertion point remain valid.

                  v.end() 不是插入点之前".

                  这篇关于为什么我得到“向量迭代器不兼容"?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Unable to access non-const member functions of objects in C++ std::set(无法访问 C++ std::set 中对象的非常量成员函数)
                  Constructing std::function argument from lambda(从 lambda 构造 std::function 参数)
                  STL BigInt class implementation(STL BigInt 类实现)
                  Sync is unreliable using std::atomic and std::condition_variable(使用 std::atomic 和 std::condition_variable 同步不可靠)
                  Move list element to the end in STL(在 STL 中将列表元素移动到末尾)
                  Why is overloading operatoramp;() prohibited for classes stored in STL containers?(为什么禁止对存储在 STL 容器中的类重载 operatoramp;()?)

                    <tfoot id='WHcsn'></tfoot>
                      <tbody id='WHcsn'></tbody>

                    <i id='WHcsn'><tr id='WHcsn'><dt id='WHcsn'><q id='WHcsn'><span id='WHcsn'><b id='WHcsn'><form id='WHcsn'><ins id='WHcsn'></ins><ul id='WHcsn'></ul><sub id='WHcsn'></sub></form><legend id='WHcsn'></legend><bdo id='WHcsn'><pre id='WHcsn'><center id='WHcsn'></center></pre></bdo></b><th id='WHcsn'></th></span></q></dt></tr></i><div id='WHcsn'><tfoot id='WHcsn'></tfoot><dl id='WHcsn'><fieldset id='WHcsn'></fieldset></dl></div>
                    • <legend id='WHcsn'><style id='WHcsn'><dir id='WHcsn'><q id='WHcsn'></q></dir></style></legend>

                          • <bdo id='WHcsn'></bdo><ul id='WHcsn'></ul>

                            <small id='WHcsn'></small><noframes id='WHcsn'>