On this page
std::forward_list<T,Allocator>::assign
|  | (1) | (since C++11) | 
|  | (2) | (since C++11) | 
|  | (3) | (since C++11) | 
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 
    
     
      
   
  
  [first, last). The behavior is undefined if either argument is an iterator into *this. 
   | This overload has the same effect as overload (1) if  | (until C++11) | 
| This overload participates in overload resolution only if  | (since C++11) | 
3) Replaces the contents with the elements from the initializer list 
  ilist.
  All iterators, pointers and references to the elements of the container are invalidated.
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 | - | initializer list to copy the values from | 
Complexity
1) Linear in 
  count.
  2) Linear in distance between 
  first and last.
  3) Linear in 
  ilist.size().
  Example
The following code uses assign to add several characters to a std::forward_list<char>:
#include <forward_list>
#include <iostream>
#include <string>
 
int main()
{
    std::forward_list<char> characters;
 
    auto print_forward_list = [&]()
    {
        for (char c : characters)
            std::cout << c << ' ';
        std::cout << '\n';
    };
 
    characters.assign(5, 'a');
    print_forward_list();
 
    const std::string extra(6, 'b');
    characters.assign(extra.begin(), extra.end());
    print_forward_list();
 
    characters.assign({'C', '+', '+', '1', '1'});
    print_forward_list();
}Output:
a a a a a
b b b b b b
C + + 1 1See also
| constructs the forward_list(public member function) | 
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
 https://en.cppreference.com/w/cpp/container/forward_list/assign