Compartilhar via


Macros

O cabeçalho fornece as seguintes macros:

ALLOCATOR_DECL

Produz um modelo de classe allocator.

#define ALLOCATOR_DECL(cache, sync, name) <alloc_template>

Comentários

A macro produz uma definição de modelo e uma especialização que, em conjunto, definem um modelo de classe allocator que usa o filtro de sincronização e um cache do tipo .

Para os compiladores que podem compilar reassociação, a definição de modelo resultante tem esta aparência:

struct rebind
   {    /* convert a name<Type> to a name<Other> */
   typedef name<Other> other;
   };

Para compiladores que não podem compilar reassociação, a definição de modelo resultante tem esta aparência:

template <class Type<class name
    : public stdext::allocators::allocator_base<Type,
    sync<stdext::allocators::rts_alloc<cache>>>
{
public:
    name() {}
    template <class Other>
    name(const name<Other>&) {}
    template <class Other>
    name& operator= (const name<Other>&)
    {
        return *this;
    }
};

CACHE_CHUNKLIST

Produz .

#define CACHE_CHUNKLIST <cache_class>

CACHE_FREELIST

Produz .

#define CACHE_FREELIST(max) <cache_class>

CACHE_SUBALLOC

Produz .

#define CACHE_SUBALLOC <cache_class>

SYNC_DEFAULT

Produz um filtro de sincronização.

#define SYNC_DEFAULT <sync_template>

Comentários

Se um compilador der suporte à compilação de aplicativos de single-threaded e multi-threaded, para aplicativos de single-threaded, a macro produzirá , em todos os outros casos, ela produzirá .

Confira também

Allocators