Этот вопрос является продолжением этот вопрос. Я понимаю что из-за push_back()
происходит новое выделение памяти и адрес первого элемента std::vector v
меняется, но не должен std::vector v2
изменить свой адрес соответственно?
#include <memory>
#include <iostream>
#include <vector>
#include <functional>
int main()
{
std::vector<int> v;
std::vector<std::reference_wrapper<int>> v2;
for (int i=0; i<3; ++i)
{
int b = i;
v.push_back(b);
v2.push_back(v.back());
std::cout << "org: " << std::addressof(v[0]) << std::endl;
std::cout << "ref: " << std::addressof(v2[0].get()) << std::endl;
}
return 0;
}
Выход:
org: 0x605010
ref: 0x605030
org: 0x605050
ref: 0x605010
org: 0x605030
ref: 0x605070
Нет, reference_wrapper похож на указатель. Когда первый вектор перераспределяется, старый объект int в памяти уничтожается, а int, на который указывает reference_wrapper, недопустим. Это ошибка, чтобы использовать его сейчас.