Freigeben über


set::get_allocator

Gibt eine Kopie des allocator-Objekts zurück, das verwendet wird, um den Satz zu erstellen.

allocator_type get_allocator( ) const;

Rückgabewert

Die Belegungsfunktion verwendet durch den Satz, um Speicherplatz zu verwalten, der der Vorlagenparameter Allocator ist.

Weitere Informationen zu Allocator, finden Sie in den Hinweisen set Class des Themas.

Hinweise

Belegungsfunktionen für die angegebene Klasse geben an, wie die Klasse Speicher verwaltet.Die standardmäßige Belegungsfunktionen, die mit STL-Containerklassen angegeben wird, ist für die meisten Programmierung Anforderungen genügen.Ihre eigene allocator-Klasse zu schreiben und die Anwendung ist ein erweitertes C++-Thema.

Beispiel

// set_get_allocator.cpp
// compile with: /EHsc
#include <set>
#include <iostream>

int main( )
{
   using namespace std;
   set <int>::allocator_type s1_Alloc;
   set <int>::allocator_type s2_Alloc;
   set <double>::allocator_type s3_Alloc;
   set <int>::allocator_type s4_Alloc;

   // The following lines declare objects
   // that use the default allocator.
   set <int> s1;
   set <int, allocator<int> > s2;
   set <double, allocator<double> > s3;

   s1_Alloc = s1.get_allocator( );
   s2_Alloc = s2.get_allocator( );
   s3_Alloc = s3.get_allocator( );

   cout << "The number of integers that can be allocated"
        << endl << "before free memory is exhausted: "
        << s2.max_size( ) << "." << endl;

   cout << "\nThe number of doubles that can be allocated"
        << endl << "before free memory is exhausted: "
        << s3.max_size( ) <<  "." << endl;

   // The following line creates a set s4
   // with the allocator of multiset s1.
   set <int> s4( less<int>( ), s1_Alloc );

   s4_Alloc = s4.get_allocator( );

   // Two allocators are interchangeable if
   // storage allocated from each can be
   // deallocated by the other
   if( s1_Alloc == s4_Alloc )
   {
      cout << "\nThe allocators are interchangeable."
           << endl;
   }
   else
   {
      cout << "\nThe allocators are not interchangeable."
           << endl;
   }
}

Beispielausgabe

Die folgende Ausgabe ist für x86.

The number of integers that can be allocated
before free memory is exhausted: 1073741823.

The number of doubles that can be allocated
before free memory is exhausted: 536870911.

The allocators are interchangeable.

Anforderungen

Header: <set>

Namespace: std

Siehe auch

Referenz

set Class

Standardvorlagenbibliothek