CARVIEW |
Select Language
HTTP/1.1 301 Moved Permanently
Server: nginx
Date: Sat, 19 Jul 2025 10:44:43 GMT
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Connection: keep-alive
Location: /reference/vector/vector/operator=/
HTTP/1.1 200 OK
Server: nginx
Date: Sat, 19 Jul 2025 10:44:43 GMT
Content-Type: text/html; charset=utf-8
Transfer-Encoding: chunked
Connection: keep-alive
ETag: W/"83ce-nYXjGD5qsgCvDLTwPxua049Hc7s"
Content-Encoding: gzip
Assigns new contents to the container, replacing its current contents, and modifying its size accordingly.
Any elements held in the container before the call are either assigned to or destroyed.
Output:
In the move assignment, iterators, pointers and references referring to elements in x are also invalidated.
The move assignment (2) modifies x.
The container and all its elements are modified.
If allocator_traits::construct is not supported with the appropriate arguments for the element constructions, or if value_type is not copy assignable (or move assignable for (2)), it causes undefined behavior.
Reference
C library:
- <cassert> (assert.h)
- <cctype> (ctype.h)
- <cerrno> (errno.h)
-
<cfenv> (fenv.h)C++11
- <cfloat> (float.h)
-
<cinttypes> (inttypes.h)C++11
- <ciso646> (iso646.h)
- <climits> (limits.h)
- <clocale> (locale.h)
- <cmath> (math.h)
- <csetjmp> (setjmp.h)
- <csignal> (signal.h)
- <cstdarg> (stdarg.h)
-
<cstdbool> (stdbool.h)C++11
- <cstddef> (stddef.h)
-
<cstdint> (stdint.h)C++11
- <cstdio> (stdio.h)
- <cstdlib> (stdlib.h)
- <cstring> (string.h)
-
<ctgmath> (tgmath.h)C++11
- <ctime> (time.h)
-
<cuchar> (uchar.h)C++11
- <cwchar> (wchar.h)
- <cwctype> (wctype.h)
Containers:
-
<array>C++11
- <deque>
-
<forward_list>C++11
- <list>
- <map>
- <queue>
- <set>
- <stack>
-
<unordered_map>C++11
-
<unordered_set>C++11
- <vector>
-
Input/Output:
Multi-threading:
-
<atomic>C++11
-
<condition_variable>C++11
-
<future>C++11
-
<mutex>C++11
-
<thread>C++11
-
Other:
- <algorithm>
- <bitset>
-
<chrono>C++11
-
<codecvt>C++11
- <complex>
- <exception>
- <functional>
-
<initializer_list>C++11
- <iterator>
- <limits>
- <locale>
- <memory>
- <new>
- <numeric>
-
<random>C++11
-
<ratio>C++11
-
<regex>C++11
- <stdexcept>
- <string>
-
<system_error>C++11
-
<tuple>C++11
-
<type_traits>C++11
-
<typeindex>C++11
- <typeinfo>
- <utility>
- <valarray>
vector
- vector::~vector
- vector::vector
member functions
- vector::assign
- vector::at
- vector::back
- vector::begin
- vector::capacity
-
vector::cbeginC++11
-
vector::cendC++11
- vector::clear
-
vector::crbeginC++11
-
vector::crendC++11
-
vector::dataC++11
-
vector::emplaceC++11
-
vector::emplace_backC++11
- vector::empty
- vector::end
- vector::erase
- vector::front
- vector::get_allocator
- vector::insert
- vector::max_size
- vector::operator[]
- vector::operator=
- vector::pop_back
- vector::push_back
- vector::rbegin
- vector::rend
- vector::reserve
- vector::resize
-
vector::shrink_to_fitC++11
- vector::size
- vector::swap
non-member overloads
public member function
<vector>
std::vector::operator=
copy (1) | vector& operator= (const vector& x); |
---|
copy (1) | vector& operator= (const vector& x); |
---|---|
move (2) | vector& operator= (vector&& x); |
initializer list (3) | vector& operator= (initializer_list<value_type> il); |
Assign content
Copies all the elements from x into the container.
The container preserves its current allocator, which is used to allocate storage in case of reallocation.
The container preserves its current allocator, which is used to allocate storage in case of reallocation.
The copy assignment (1) copies all the elements from x into the container (with x preserving its contents).
The move assignment (2) moves the elements of x into the container (x is left in an unspecified but valid state).
The initializer list assignment (3) copies the elements of il into the container.
The container preserves its current allocator, except if the allocator traits indicate that x's allocator should propagate. This allocator is used (through its traits) to allocate and deallocate storage if a reallocation happens, and to construct or destroy elements, if needed.
The move assignment (2) moves the elements of x into the container (x is left in an unspecified but valid state).
The initializer list assignment (3) copies the elements of il into the container.
The container preserves its current allocator, except if the allocator traits indicate that x's allocator should propagate. This allocator is used (through its traits) to allocate and deallocate storage if a reallocation happens, and to construct or destroy elements, if needed.
Any elements held in the container before the call are either assigned to or destroyed.
Parameters
- x
- A vector object of the same type (i.e., with the same template parameters, T and Alloc).
- il
- An initializer_list object. The compiler will automatically construct such objects from initializer list declarators.
Member type value_type is the type of the elements in the container, defined in vector as an alias of its first template parameter (T).
Return value
*thisExample
|
|
Output:
Size of foo: 0 Size of bar: 3 |
Complexity
Linear in size.Iterator validity
All iterators, references and pointers related to this container before the call are invalidated.In the move assignment, iterators, pointers and references referring to elements in x are also invalidated.
Data races
All copied elements are accessed.The move assignment (2) modifies x.
The container and all its elements are modified.
Exception safety
Basic guarantee: if an exception is thrown, the container is in a valid state.If allocator_traits::construct is not supported with the appropriate arguments for the element constructions, or if value_type is not copy assignable (or move assignable for (2)), it causes undefined behavior.
See also
- vector::assign
- Assign vector content (public member function)
Home page | Privacy policy
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us