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
указатель на ссылку). Однако указатель на ссылку недопустим , поэтому выражение сформировано некорректно .