Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/container/vector/assign"

From cppreference.com
< cpp‎ | container‎ | vector
m (Shorten template names. Use {{lc}} where appropriate.)
m (Undo revision 124707 by 193.145.124.20 (talk) recovery after vandalism)
 
(2 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
{{include page|cpp/container/assign|vector}}
 
{{include page|cpp/container/assign|vector}}
  
[[de:cpp/container/vector/assign]]
+
{{langlinks|de|es|fr|it|ja|pt|ru|zh}}
[[es:cpp/container/vector/assign]]
+
[[fr:cpp/container/vector/assign]]
+
[[it:cpp/container/vector/assign]]
+
[[ja:cpp/container/vector/assign]]
+
[[pt:cpp/container/vector/assign]]
+
[[ru:cpp/container/vector/assign]]
+
[[zh:cpp/container/vector/assign]]
+

Latest revision as of 12:41, 4 December 2020

 
 
 
 
void assign( size_type count, const T& value );
(1) (constexpr since C++20)
template< class InputIt >
void assign( InputIt first, InputIt last );
(2) (constexpr since C++20)
void assign( std::initializer_list<T> ilist );
(3) (since C++11)
(constexpr since C++20)

Replaces the contents of the container.

1) Replaces the contents with count copies of value value.
2) Replaces the contents with copies of those in the range [firstlast).
If either argument is an iterator into *this, the behavior is undefined.

This overload has the same effect as overload (1) if InputIt is an integral type.

(until C++11)

This overload participates in overload resolution only if InputIt satisfies LegacyInputIterator.

(since C++11)
3) Replaces the contents with the elements from ilist.

All iterators (including the end() iterator) and all references to the elements are invalidated.

Contents

[edit] Parameters

count - the new size of the container
value - the value to initialize elements of the container with
first, last - the range to copy the elements from
ilist - std::initializer_list to copy the values from

[edit] Complexity

1) Linear in count.
2) Linear in distance between first and last.
3) Linear in ilist.size().

[edit] Example

The following code uses assign to add several characters to a std::vector<char>:

#include <vector>
#include <iostream>
#include <string>
 
int main()
{
    std::vector<char> characters;
 
    auto print_vector = [&]()
    {
        for (char c : characters)
            std::cout << c << ' ';
        std::cout << '\n';
    };
 
    characters.assign(5, 'a');
    print_vector();
 
    const std::string extra(6, 'b');
    characters.assign(extra.begin(), extra.end());
    print_vector();
 
    characters.assign({'C', '+', '+', '1', '1'});
    print_vector();
}

Output:

a a a a a
b b b b b b
C + + 1 1

Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
LWG 2209 C++98 the replacement operation was required to be implemented as
erasing all existing elements followed by inserting the given elements
removed the
requirement

[edit] See also

assigns a range of values to the container
(public member function) [edit]
assigns values to the container
(public member function) [edit]