std::deque<T,Allocator>:: operator=
|
deque
&
operator
=
(
const
deque
&
other
)
;
|
(1) | (constexpr начиная с C++26) |
| (2) | ||
|
deque
&
operator
=
(
deque
&&
other
)
;
|
(начиная с C++11)
(до C++17) |
|
|
deque
&
operator
=
(
deque
&&
other
)
noexcept ( /* см. ниже */ ) ; |
(начиная с C++17)
(constexpr начиная с C++26) |
|
|
deque
&
operator
=
(
std::
initializer_list
<
value_type
>
ilist
)
;
|
(3) |
(начиная с C++11)
(constexpr начиная с C++26) |
Заменяет содержимое контейнера.
Пусть
traits
будет
std::
allocator_traits
<
allocator_type
>
:
|
Если traits :: propagate_on_container_copy_assignment :: value равно true , аллокатор * this заменяется копией аллокатора other . Если после присваивания аллокатор * this будет сравниваться как неравный своему старому значению, старый аллокатор используется для освобождения памяти, затем новый аллокатор используется для её выделения перед копированием элементов. В противном случае память, принадлежащая * this , может быть повторно использована, когда это возможно. В любом случае, элементы, изначально принадлежавшие * this , могут быть либо уничтожены, либо заменены через поэлементное копирующее присваивание. |
(начиная с C++11) |
Содержание |
Параметры
| other | - | другой контейнер для использования в качестве источника данных |
| ilist | - | список инициализации для использования в качестве источника данных |
Возвращаемое значение
* this
Сложность
Исключения
|
2)
noexcept
спецификация:
noexcept
(
std::
allocator_traits
<
Allocator
>
::
is_always_equal
::
value
)
|
(начиная с C++17) |
Примечания
После операции перемещения контейнера (перегрузка ( 2 ) ), если поэлементное перемещение не принудительно вызвано несовместимыми аллокаторами, ссылки, указатели и итераторы (кроме конечного итератора) на other остаются действительными, но ссылаются на элементы, которые теперь находятся в * this . Текущий стандарт обеспечивает эту гарантию через общее положение в [container.reqmts]/67 , а более прямая гарантия рассматривается через LWG issue 2321 .
Пример
Следующий код использует operator = для присваивания одного std::deque другому:
#include <initializer_list> #include <iostream> #include <iterator> #include <deque> void print(const auto comment, const auto& container) { auto size = std::size(container); std::cout << comment << "{ "; for (const auto& element : container) std::cout << element << (--size ? ", " : " "); std::cout << "}\n"; } int main() { std::deque<int> x{1, 2, 3}, y, z; const auto w = {4, 5, 6, 7}; std::cout << "Initially:\n"; print("x = ", x); print("y = ", y); print("z = ", z); std::cout << "Copy assignment copies data from x to y:\n"; y = x; print("x = ", x); print("y = ", y); std::cout << "Move assignment moves data from x to z, modifying both x and z:\n"; z = std::move(x); print("x = ", x); print("z = ", z); std::cout << "Assignment of initializer_list w to z:\n"; z = w; print("w = ", w); print("z = ", z); }
Вывод:
Initially:
x = { 1, 2, 3 }
y = { }
z = { }
Copy assignment copies data from x to y:
x = { 1, 2, 3 }
y = { 1, 2, 3 }
Move assignment moves data from x to z, modifying both x and z:
x = { }
z = { 1, 2, 3 }
Assignment of initializer_list w to z:
w = { 4, 5, 6, 7 }
z = { 4, 5, 6, 7 }
Смотрите также
создает
deque
(публичная функция-член) |
|
|
присваивает значения контейнеру
(публичная функция-член) |