在下面的代码中,Var的两个实例的_bla成员似乎代表相同的内存位置,因为在一个实例上设置值也会改变另一个实例.执行程序时,输出为:
v: 44 v2: 44 x: 22
Run Code Online (Sandbox Code Playgroud)
有人可以解释一下吗?
#include <iostream>
using namespace std;
template<typename T> class Var {
T &_bla;
public:
Var(T t) : _bla(t) {}
int bla() const {
return _bla;
}
};
using namespace std;
int main() {
cout << "Hello, World!" << endl;
int x = 22;
Var<int> v = {x};
Var<int> v2 = {44};
cout << "v: " << v.bla() << " v2: " << v2.bla() << " x: " << x << endl;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
它是未定义的行为,这意味着一切皆有可能.
tctor 的参数是通过值传递的,它将从参数中复制,然后_bla通过引用分配,当超出ctor的范围时,参数t被释放,现在成员变量_bla变为悬空引用.
您可以重新考虑您的设计,您是否需要成员变量作为参考?什么应该是参数的类型t?通过const引用,通过引用,按值?(在你的情况下,按值传递它显然是错误的.)当你使用成员变量的引用时,最好仔细考虑.