TL; DR
Используйте std::reference_wrapperкак это:
#include <functional>
#include <string>
#include <vector>
#include <iostream>
int main()
{
std::string hello = "Hello, ";
std::string world = "everyone!";
typedef std::vector<std::reference_wrapper<std::string>> vec_t;
vec_t vec = {hello, world};
vec[1].get() = "world!";
std::cout << hello << world << std::endl;
return 0;
}
Demo
Длинный ответ
Как предполагает стандарт , для стандартного контейнера, Xсодержащего объекты типа T, Tдолжен быть Erasableот X.
Erasable означает, что следующее выражение правильно сформировано:
allocator_traits<A>::destroy(m, p)
Aявляется типом распределителя контейнера, mявляется экземпляром распределителя и pявляется указателем типа *T. Смотрите здесь для Erasableопределения.
По умолчанию std::allocator<T>используется как распределитель вектора. При использовании распределителя по умолчанию требование эквивалентно действительности p->~T()(обратите внимание, что Tэто ссылочный тип и pуказатель на ссылку). Однако указатель на ссылку недопустим , поэтому выражение сформировано некорректно .