Sdílet prostřednictvím


Jak zadat další informace o kódu pomocí _Analysis_assume_

Můžete poskytnout rady pro nástroj pro analýzu kódu pro kód C/C++, který pomáhá procesu analýzy a omezení upozornění. Pokud chcete poskytnout další informace, použijte následující makro funkce:

_Analysis_assume_( expr )

expr – libovolný výraz, který se předpokládá jako pravdivý.

Nástroj pro analýzu kódu předpokládá, že podmínka reprezentovaná výrazem expr je pravdivá v okamžiku, kdy se funkce zobrazí. A zůstane pravdivý, dokud expr se nezmění, například přiřazením proměnné.

Poznámka:

_Analysis_assume_ nemá vliv na optimalizaci kódu. Mimo nástroj pro _Analysis_assume_ analýzu kódu je definován jako no-op.

Příklad

Následující kód slouží _Analysis_assume_ k opravě upozornění analýzy kódu 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_ by měla být použita jako poslední možnost. Měli bychom se nejprve pokusit, aby byly kontrakty funkcí přesnější. V tomto případě bychom mohli místo použití _Analysis_assume_zlepšit smlouvuFreeAndNull:

#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);
}

Viz také