Share via


<allocators> macros

ALLOCATOR_DECL

Da como resultado una plantilla de clase de asignador.

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

Comentarios

La macro produce una definición de plantilla template <class Type> class name {.....} y una especialización template <> class name<void> {.....} que definen una clase de plantilla de asignador que usa el filtro de sincronización sync y una caché de tipo cache.

En el caso de los compiladores que pueden compilar reenlaces, la definición de plantilla resultante tiene el siguiente aspecto:

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

En el caso de los compiladores que no pueden compilar reenlaces, la definición de plantilla resultante tiene el siguiente aspecto:

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

Produce stdext::allocators::cache_chunklist<sizeof(Type)>.

#define CACHE_CHUNKLIST <cache_class>

Comentarios

CACHE_FREELIST

Produce stdext::allocators::cache_freelist<sizeof(Type), max>.

#define CACHE_FREELIST(max) <cache_class>

Comentarios

CACHE_SUBALLOC

Produce stdext::allocators::cache_suballoc<sizeof(Type)>.

#define CACHE_SUBALLOC <cache_class>

Comentarios

SYNC_DEFAULT

Da como resultado un filtro de sincronización.

#define SYNC_DEFAULT <sync_template>

Comentarios

Si un compilador admite la compilación de aplicaciones de un único subproceso y de varios, en el caso de las aplicaciones de un único subproceso la macro produce stdext::allocators::sync_none; en todos los demás casos, produce stdext::allocators::sync_shared.

Consulte también

<allocators>