Udostępnij za pośrednictwem


uninitialized_fill

Kopiuje obiekty z określoną wartością do niezainicjowanego zakresu docelowego.

template<class ForwardIterator, class Type> 
   void uninitialized_fill( 
      ForwardIterator _First,  
      ForwardIterator _Last, 
      const Type& _Val 
   );

Parametry

  • _First
    Do przodu sterująca, adresowania pierwszy element w zakresie docelowym, który może zostać wszczęte.

  • _Last
    Do przodu sterująca, adresowania ostatniego elementu w zakresie docelowym, który może zostać wszczęte.

  • _Val
    Wartość wykorzystana do zainicjowania zakresu docelowego.

Uwagi

Ten algorytm umożliwia oddzielenie alokacji pamięci z konstrukcji obiektów.

Funkcja szablon skutecznie wykonuje:

while ( _First!= _Last )
   new ( (void *)&*_First ++)
      iterator_traits<ForwardIterator>::value_type ( _Val );

o ile kod zgłasza wyjątek.W takim przypadku wszystkie obiekty zbudowane są niszczone, a rethrown wyjątku.

Przykład

// memory_uninit_fill.cpp
// compile with: /EHsc
#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 ( 25 );
   Integer* Array = ( Integer* ) malloc( N * sizeof( int ) );
   uninitialized_fill( Array, Array + N, val );
   int i;
   cout << "The initialized Array contains: ";
      for ( i = 0 ; i < N; i++ )
      {
         cout << Array [ i ].get( ) << " ";
      }
   cout << endl;
}
  

Wymagania

Nagłówek: <pamięć>

Przestrzeń nazw: std