Como especificar informações de código adicionais usando _Analysis_assume_
Você pode fornecer dicas para a ferramenta de análise de código para código C/C++ que ajudam no processo de análise e reduzem avisos. Para fornecer informações adicionais, use a seguinte macro de função:
_Analysis_assume_( expr )
expr
– qualquer expressão supostamente avaliada como verdadeira.
A ferramenta de análise de código pressupõe que a condição representada pela expressão expr
seja verdadeira no ponto em que a função é exibida. E, ele permanece verdadeiro até expr
ser alterado, por exemplo, por atribuição a uma variável.
Observação
_Analysis_assume_
não afeta a otimização de código. Fora da ferramenta de análise de código, _Analysis_assume_
é definida como uma operação sem operações.
Exemplo
O código a seguir usa _Analysis_assume_
para corrigir o aviso de análise de código C6388:
#include <windows.h>
#include <sal.h>
// Requires pc to be null.
void f(_Pre_null_ char* pc);
// Calls free and sets ch to null.
void FreeAndNull(char** ch);
void test()
{
char* pc = (char*)malloc(5);
FreeAndNull(&pc);
_Analysis_assume_(pc == NULL);
f(pc);
}
_Analysis_assume_
deve ser usado como último recurso. Devemos primeiro tentar tornar os contratos das funções mais precisos. Neste caso, poderíamos melhorar o contrato de FreeAndNull
em vez de usar _Analysis_assume_
:
#include <windows.h>
#include <sal.h>
// Requires pc to be null.
void f(_Pre_null_ char* pc);
// Calls free and sets ch to null.
_At_(*ch, _Post_null_)
void FreeAndNull(char** ch);
void test()
{
char* pc = (char*)malloc(5);
FreeAndNull(&pc);
f(pc);
}