问题描述
如果我有以下情况:
#include <iostream>
#include <string>
#include <type_traits>
struct A{
~A(){std::cout << "killed '" << a <<"'\n";}
int a = 3;
};
template<typename T>
void foo(T&& r){ // Is r still valid here???
std::cout << "Running: " << r.a << "\n";
}
int main()
{
A* a = new A{3};
foo(true ? A{4} : *a);
}
我没有得到令人惊讶的结果:
Running: 4
killed '4'
http://coliru.stacked-crooked.com/a/b218bef991ef24d2
但是我在使用 MSVC 16 (VS 19) 和 C++14 时崩溃了...
我想知道在上面的例子中是否没有生命周期延长。应该有,因为我将纯右值 A
绑定到作为右值引用的 A&&
(T&&
)。当绑定到 rvalue-reference 或 const lvalue-references 时,生命周期延长得到保证。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)