Udostępnij za pośrednictwem


uninitialized_fill_n

Kopiuje obiekty z określoną wartością do określonej liczby elementów w niezainicjowanym zakresie docelowym.

template<class FwdIt, class Size, class Type> 
   void uninitialized_fill_n( 
      ForwardIterator _First,  
      Size _Count, 
      const Type& _Val 
   );

Parametry

  • _First
    Iterator do przodu, odnoszący się do pierwszego elementu w zakresie docelowym, który ma być zainicjowany.

  • _Count
    Liczba elementów, które mają być zainicjowane.

  • _Val
    Wartość wykorzystana do zainicjowania zakresu docelowego.

Uwagi

Ten algorytm umożliwia oddzielenie alokacji pamięci od konstrukcji obiektu.

Funkcja szablonu skutecznie wykonuje:

while ( 0 < count-- )
   new ( ( void * )&*_First ++ )
      iterator_traits<ForwardIterator>::value_type( _Val );

chyba że kod zgłasza wyjątek.W takim przypadku wszystkie skonstruowane obiekty są niszczone, a wyjątek jest zgłaszany ponownie.

Przykład

// memory_uninit_fill_n.cpp
// compile with: /EHsc /W3
#include <memory>
#include <iostream>

using namespace std;

class Integer {   // No default constructor
public:
   Integer( int x ) : val( x ) {}
   int get( ) { return val; }
private:
   int val;
};

int main() {
   const int N = 10;
   Integer val ( 60 );
   Integer* Array = ( Integer* ) malloc( N * sizeof( int ) );
   uninitialized_fill_n( Array, N, val );  // C4996
   int i;
   cout << "The uninitialized Array contains: ";
   for ( i = 0 ; i < N; i++ )
      cout << Array [ i ].get( ) <<  " ";
}

Dane wyjściowe

The uninitialized Array contains: 60 60 60 60 60 60 60 60 60 60 

Wymagania

Nagłówek: <memory>

Przestrzeń nazw: std