Scroll to navigation

std::vector::operator=(3) C++ Standard Libary std::vector::operator=(3)

NAME

std::vector::operator= - std::vector::operator=

Synopsis


vector& operator=( const vector& other ); (until
C++20)
constexpr vector& operator=( const vector& other ); (since
C++20)
(since
vector& operator=( vector&& other ); C++11)
(until
C++17)
(since
vector& operator=( vector&& other ) noexcept(/* see (1) C++17)
below */); (until
(2) C++20)
constexpr vector& operator=( vector&& other ) (since
noexcept(/* see below */); C++20)
(since
vector& operator=( std::initializer_list<T> ilist ); C++11)
(3) (until
C++20)
constexpr vector& operator=( (since
std::initializer_list<T> ilist ); C++20)


Replaces the contents of the container.


1) Copy assignment operator. Replaces the contents with a copy of the contents of
other.

If std::allocator_traits<allocator_type>::propagate_on_container_copy_assignment::value is true, the allocator of *this is replaced by a copy of that of other. If the allocator of *this after assignment would compare unequal to its old value, the old (since allocator is used to deallocate the memory, then the new allocator is used to C++11) allocate it before copying the elements. Otherwise, the memory owned by *this may be reused when possible. In any case, the elements originally belong to *this may be either destroyed or replaced by element-wise copy-assignment.


2) Move assignment operator. Replaces the contents with those of other using move
semantics (i.e. the data in other is moved from other into this container). other is
in a valid but unspecified state afterwards.
If
std::allocator_traits<allocator_type>::propagate_on_container_move_assignment::value
is true, the allocator of *this is replaced by a copy of that of other. If it is
false and the allocators of *this and other do not compare equal, *this cannot take
ownership of the memory owned by other and must move-assign each element
individually, allocating additional memory using its own allocator as needed. In any
case, all elements originally belong to *this are either destroyed or replaced by
element-wise move-assignment.
3) Replaces the contents with those identified by initializer list ilist.

Parameters


other - another container to use as data source
ilist - initializer list to use as data source

Return value


*this

Complexity


1) Linear in the size of *this and other.
2) Linear in the size of *this unless the allocators do not compare equal and do not
propagate, in which case linear in the size of *this and other.
3) Linear in the size of *this and ilist.

Exceptions

May throw implementation-defined exceptions. (until
C++17) 1,3) May throw implementation-defined exceptions. 2) (since noexcept specification: C++17) noexcept(std::allocator_traits<Allocator>::propagate_on_container_move_assignment::value || std::allocator_traits<Allocator>::is_always_equal::value)

Notes


After container move assignment (overload (2)), unless element-wise move assignment
is forced by incompatible allocators, references, pointers, and iterators (other
than the end iterator) to other remain valid, but refer to elements that are now in
*this. The current standard makes this guarantee via the blanket statement in
[container.requirements.general]/12, and a more direct guarantee is under
consideration via LWG 2321.

Example


The following code uses operator= to assign one std::vector to another:

// Run this code


#include <vector>
#include <iterator>
#include <iostream>


void print(auto const comment, auto const& container)
{
auto size = std::size(container);
std::cout << comment << "{ ";
for (auto const& element: container)
std::cout << element << (--size ? ", " : " ");
std::cout << "}\n";
}


int main()
{
std::vector<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);
}

Output:


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 }

See also


constructor constructs the vector
(public member function)
assign assigns values to the container
(public member function)

2022.07.31 http://cppreference.com