set::get_allocator
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