Compartilhar via


set::get_allocator

Retorna uma cópia do objeto do alocador usado para construir o conjunto.

allocator_type get_allocator( ) const;

Valor de retorno

O alocador usado pelo conjunto para gerenciar a memória, que é o parâmetro Allocatordo modelo.

Para obter mais informações sobre como Allocator, consulte a seção comentários do tópico de Classe set .

Comentários

Os alocadores da classe de conjunto especificam como a classe gerencia o armazenamento. Alocadores os padrões fornecidos com classes de contêineres STL são suficientes para a maioria das necessidades de programação. Gravar e usar sua própria classe do alocador é um tópico avançada C++.

Exemplo

// 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;
   }
}

Saída de Exemplo

A saída a seguir é para 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.

Requisitos

defineCabeçalho: <>

Namespace: std

Consulte também

Referência

Classe set

Biblioteca de Modelos Padrão