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