Compartilhar via


Aviso C26815

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

Comentários

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 ficará embaralhado.

Essa verificação reconhece exibições e proprietários da STL (Biblioteca de Modelos Padrão) do C++. Para ensinar essa verificação sobre tipos criados pelo usuário, use a [[msvc::lifetimebound]] anotação. O [[msvc::lifetimebound]] suporte é 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 o tempo de vida 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();
}

Confira também

C26816
ES.65: não desreferenciar um ponteiro inválido