Compartir vía


Advertencia C26823

Desreferenciar un puntero posiblemente nulo 'variable' (lifetime.1)

Comentarios

La desreferenciación de un puntero nulo es un problema frecuente en C y C++. Tenemos varias comprobaciones para tratar estos problemas. Consulte esta entrada de blog para obtener una comparación. Cuando el motor de análisis deduce que el valor de un puntero puede ser NULL y ve que el puntero obtiene desreferenciado, emitirá una C26823 advertencia. Puede habilitar C26822 solo para un análisis más permisivo. Esta comprobación también admite Anotaciones SAL y gsl::not_null para describir invariables del código.

Ejemplo

void invalidate(int **pp);
void condition_null_dereference_invalidated(int* p)
{
    if (p)
        return;

    invalidate(&p);
    // The call above could reset the value of `p`, thus the low confidence warning.
    *p = 5; // warning: C26823
}

Para resolver esta advertencia, asegúrese de que no hay ninguna desreferencia de puntero null en el código, potencialmente agregando comprobaciones nulas. En caso de que se descubra que el código es correcto, los resultados de falsos positivos se suelen poder corregir mediante gsl::not_null o Anotaciones SAL. A continuación se muestran algunos ejemplos de cómo usar algunas de esas anotaciones:

_Notnull_ int *get_my_ptr(); 
gsl::not_null<int *> get_my_ptr2(); 

void local_analysis(int *p) { 
    _Analysis_assume_(p != nullptr); 
    *p = 42; 
} 

void local_analysis2(_In_ int *p) { 
    int a = *p; 
}