Compartir a través de


IHttpCacheSpecificData::ReferenceCacheData (Método)

Incrementa el recuento de referencias internas de los datos almacenados en caché.

Sintaxis

virtual VOID ReferenceCacheData(  
   VOID  
) = 0;  

Parámetros

Este método no toma parámetros.

Seguridad para subprocesos

Las clases que implementan la interfaz IHttpCacheSpecificData son seguras para subprocesos para los métodos y ReferenceCacheDataDereferenceCacheData.

Comentarios

Las clases que implementan la IHttpCacheSpecificData interfaz usan el recuento de referencias que es seguro para subprocesos para la administración de memoria. Cuando se construye un IHttpCacheSpecificData puntero, el recuento de referencias internas (una private variable miembro) se establece en 1. Cuando se llama al ReferenceCacheData método , este recuento de referencias se incrementa en 1. Cuando se llama al DereferenceCacheData método , este mismo recuento de referencias se reduce en 1. Solo cuando el recuento de referencias va a 0 es el IHttpCacheSpecificData puntero quitado del montón. Este esquema garantiza que el IHttpCacheSpecificData puntero no se eliminará hasta que el último cliente de ese puntero llame a DereferenceCacheData.

Notas para los implementadores

Las implementaciones de ReferenceCacheData método y DereferenceCacheData deben ser seguras para subprocesos para una IHttpCacheSpecificData interfaz. Los implementadores deben proporcionar protected o private destructores a los que se llama internamente solo cuando el recuento de referencias va a 0.

Notas para autores de la llamada

Los clientes nunca deben intentar convertir un IHttpCacheSpecificData puntero a una clase más específica y, a continuación, llamar delete directamente. En su lugar, los clientes deben llamar al ReferenceCacheData método exactamente una vez cuando se recupera un puntero a una IHttpCacheSpecificData interfaz y, a continuación, llamar al DereferenceCacheData método cuando ya no se tenga acceso al IHttpCacheSpecificData puntero. Debe llamar a los ReferenceCacheData métodos y DereferenceCacheData tan pronto como sea posible, respectivamente, para garantizar que un IHttpCacheSpecificData puntero será válido en el montón cuando se acceda a él y elimine cuando ya no sea necesario.

Ejemplo

En el ejemplo de código siguiente se muestra una clase denominada MySpecificData que implementa los IHttpCacheSpecificData métodos.

// Create a class that implements the IHttpCacheSpecificData interface.  
class MySpecificData : public IHttpCacheSpecificData  
{  
public:  
    // Create a public constructor.  
    // Set the internal reference count to 1.  
    MySpecificData ()  
    {  
        m_cRefs = 1;  
    }  
  
    // Increment the internal reference count.  
    virtual VOID ReferenceCacheData(VOID)  
    {  
        InterlockedIncrement(&m_cRefs);  
    }  
  
    // Decrement the internal reference count.  
    virtual VOID DereferenceCacheData(VOID)  
    {  
        // Decrement the reference count and delete this  
        // if the count is 0.  
        if (0 == InterlockedDecrement(&m_cRefs))  
        {  
            delete this;  
        }  
    }  
  
    // To do: implement custom MySpecificData implementation.  
  
private:  
    // Create a private destructor called from DereferenceCacheData.  
    virtual ~MySpecificData ()  
    {  
  
    }  
  
    // Create a private reference count member.  
    LONG m_cRefs;  
}  

Requisitos

Tipo Descripción
Remoto - IIS 7.0 en Windows Vista
- IIS 7.5 en Windows 7
- IIS 8.0 en Windows 8
- IIS 10.0 en Windows 10
Servidor - IIS 7.0 en Windows Server 2008
- IIS 7.5 en Windows Server 2008 R2
- IIS 8.0 en Windows Server 2012
- IIS 8.5 en Windows Server 2012 R2
- IIS 10.0 en Windows Server 2016
Producto - IIS 7.0, IIS 7.5, IIS 8.0, IIS 8.5, IIS 10.0
- IIS Express 7.5, IIS Express 8.0, IIS Express 10.0
Encabezado Httpserv.h

Consulte también

IHttpCacheSpecificData (Interfaz)