uninitialized_fill_n
Kopie obiektów określonej wartości do określonej liczby elementów do zakresu docelowego niezainicjowany.
template<class FwdIt, class Size, class Type>
void uninitialized_fill_n(
ForwardIterator _First,
Size _Count,
const Type& _Val
);
Parametry
_First
Iteratora przodu adresowania pierwszy element w zakresie docelowym, było inicjowane._Count
Liczba elementów do zainicjowane._Val
Wartość do zainicjowania zakresu docelowego.
Uwagi
Algorytm ten umożliwia rozdzielenie alokacji pamięci z konstrukcji obiektów.
Funkcja szablonu skutecznie wykonywana:
while ( 0 < count-- )
new ( ( void * )&*_First ++ )
iterator_traits<ForwardIterator>::value_type( _Val );
chyba że kod generuje wyjątek.W takim przypadku wszystkie obiekty zbudowane są niszczone i wyjątek jest rethrown.
uninitialized_fill_nma dwa powiązane formularze:
Informacji na temat zachowania tych funkcji, zobacz Iteratory zaznaczone.
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>
Obszar nazw: std