次の方法で共有


uninitialized_fill_n

初期化されていない先の範囲に指定した数の要素にある値オブジェクトをコピーします。

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

パラメーター

  • _First
    開始する先の範囲の最初の要素を指定する前方反復子。

  • _Count
    初期化する要素の数。

  • _Val
    コピー先の範囲を初期化するために使用する値。

解説

このアルゴリズムは、オブジェクトの構造からのメモリ割り当てを分離できます。

テンプレート関数は、実装します:

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

コードが例外をスローします。その場合は、すべての構築されたオブジェクトは破棄され、例外がスローされます。

uninitialized_fill_n 2 に関連する二つの形式があります:

ついては、これらの関数がどのようにするか、チェックを行う反復子を参照してください。

使用例

// 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( ) <<  " ";
}

出力

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

必要条件

ヘッダー : <memory>

名前空間: std