Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Gibt eine Kopie des Zuweisungsobjekts zurück, das verwendet wird, um den Satz zu erstellen.
allocator_type get_allocator( ) const;
Rückgabewert
Die Zuweisung wird vom Satz, um Speicherplatz verwalten, der der Vorlagenparameter Allocator ist.
Weitere Informationen zu Allocator, finden Sie im Abschnitt Hinweise des Themas set-Klasse.
Hinweise
Zuweisungen für die angegebene Klasse geben an, wie die Klasse Speicher verwaltet. Die Standardzuweisungen, die mit STL-Containerklassen angegeben werden, ist für die meisten Anforderungen Programmierung ausreichend. 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 gilt 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