Partilhar via


Aviso C26815

O ponteiro está pendurado porque aponta para uma instância temporária que foi destruída. (ES.65)

Observações

O ponteiro ou modo de exibição criado refere-se a um objeto temporário sem nome que é destruído no final da instrução. O ponteiro ou a vista irá balançar.

Esta verificação reconhece visões e proprietários da Biblioteca de Modelo Padrão (STL) do C++. Para ensinar esta verificação sobre tipos criados pelo usuário, use a anotação [[msvc::lifetimebound]]. O suporte [[msvc::lifetimebound]] é novo no MSVC 17.7.

Nome da análise de código: LIFETIME_LOCAL_USE_AFTER_FREE_TEMP

Exemplo

Considere o seguinte código compilado em uma versão C++ antes do C++23:

std::optional<std::vector<int>> getTempOptVec();

void loop() {
    // Oops, the std::optional value returned by getTempOptVec gets deleted
    // because there is no reference to it.
    for (auto i : *getTempOptVec()) // warning C26815
    {
        // do something interesting
    }
}

void views()
{
    // Oops, the 's' suffix turns the string literal into a temporary std::string.
    std::string_view value("This is a std::string"s); // warning C26815
}

struct Y { int& get() [[msvc::lifetimebound]]; };
void f() {
    int& r = Y{}.get(); // warning C26815
}

Esses avisos podem ser corrigidos estendendo a vida útil do objeto temporário.

std::optional<std::vector<int>> getTempOptVec();

void loop() {
    // Fixed by extending the lifetime of the std::optional value by giving it a name.
    auto temp = getTempOptVec();
    for (auto i : *temp)
    {
        // do something interesting
    }
}

void views()
{
    // Fixed by changing to a constant string literal.
    std::string_view value("This is a string literal");
}

struct Y { int& get() [[msvc::lifetimebound]]; };
void f() {
    Y y{};
    int& r = y.get();
}

Ver também

C26816
ES.65: Não desreferencie um ponteiro inválido