首页 > 解决方案 > C++ 基向量指派生向量

问题描述

为什么这段代码不起作用?有两个向量。基本向量元素应将派生的向量元素作为参考(而不是副本)。输出是随机数,因此,由于某种原因,reference_wrapper 元素没有正确引用派生元素,而是。

#include <iostream>
#include <vector>

struct Base
{
    Base (int a) : a_ (a) {}
    int a_;
};

struct DerivedA : Base
{
    DerivedA (int a) : Base (a) {}
};

int main(int argc, const char * argv[]) {
    std::vector <std::reference_wrapper <Base>> b;
    std::vector <DerivedA> d;

    const int num = 100;
    for (int i = 0; i < num; i++)
    {
        d.push_back (i);
        b.push_back (d.back());
    }

    for (int i = 0; i < num; i++)
        std::cout << b[i].get().a_;

    return 0;
}

标签: c++vectorreferencewrapper

解决方案


如果您查看std::vector::push_back()的文档,它清楚地说:

如果新的 size() 大于 capacity() 则所有迭代器和引用(包括过去的迭代器)都将失效。

重点是我的。因此,在您的情况下会发生这种情况,要修复它,您需要确保向量的容量足够大或使用另一个不会失效的容器。例如std::deque

所有迭代器,包括过去的迭代器,都无效。没有引用无效。

或者存储元素的索引而不是引用。


推荐阅读