hash_multiset::get_allocator
Hinweis |
---|
Diese API ist veraltet.Die Alternative ist unordered_multiset Class. |
Gibt eine Kopie des allocator-Objekts zurück, das verwendet wird, um das hash_multiset zu erstellen.
Allocator get_allocator( ) const;
Rückgabewert
Die Belegungsfunktion wird vom hash_multiset, um Speicherplatz zu verwalten, der der Vorlagenparameter Allocator der Klasse ist.
Weitere Informationen zu Allocator, finden Sie in den Hinweisen hash_multiset Class des Themas.
Hinweise
Belegungsfunktionen für die hash_multiset 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.
In Visual C++ .NET 2003, sind Member der <hash_map> und <hash_set> Headerdateien nicht mehr im stdnamespace, sondern sind in den stdext Namespace verschoben wurde.Weitere Informationen finden Sie unter Der stdext-Namespace.
Beispiel
// hash_multiset_get_allocator.cpp
// compile with: /EHsc
#include <hash_set>
#include <iostream>
int main( )
{
using namespace std;
using namespace stdext;
// The following lines declare objects
// that use the default allocator.
hash_multiset <int, hash_compare <int, less<int> > > hms1;
hash_multiset <int, hash_compare <int, greater<int> > > hms2;
hash_multiset <double, hash_compare <double,
less<double> >, allocator<double> > hms3;
hash_multiset <int, hash_compare <int,
greater<int> > >::allocator_type hms2_Alloc;
hash_multiset <double>::allocator_type hms3_Alloc;
hms2_Alloc = hms2.get_allocator( );
cout << "The number of integers that can be allocated"
<< endl << "before free memory is exhausted: "
<< hms1.max_size( ) << "." << endl;
cout << "The number of doubles that can be allocated"
<< endl << "before free memory is exhausted: "
<< hms3.max_size( ) << "." << endl;
// The following lines create a hash_multiset hms4
// with the allocator of hash_multiset hms1.
hash_multiset <int>::allocator_type hms4_Alloc;
hash_multiset <int> hms4;
hms4_Alloc = hms2.get_allocator( );
// Two allocators are interchangeable if
// storage allocated from each can be
// deallocated by the other
if( hms2_Alloc == hms4_Alloc )
{
cout << "The allocators are interchangeable."
<< endl;
}
else
{
cout << "The 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: <hash_set>
Namespace: stdext