你好,有人可以帮我这个吗? 我有一个班级成员参考:
class name{
int& broj;
string ulica;
并有构造函数:
public:
kuca(int b, string s) :broj(b)
{
ulica = s;
}
和输出的信息类
void info(){
cout << broj << ulica << endl;
}
};
当我创建对象并尝试输出它时
int isbn = 1;
name a(isbn, "text");
a.info();
作为参考值我似乎得到垃圾/随机值,而其他属性写得很好:
-858993460 text
答案 0 :(得分:3)
你必须写至少
kuca( int &b, string s) :broj(b)
^^^^^^
{
ulica = s;
}
否则变量b是构造函数的局部变量/对象,在执行构造函数后将被销毁,并且引用将无效。
答案 1 :(得分:3)
引用成员总是有成为悬空的危险:当引用引用的原始对象超出范围时。在你的情况下,这发生了立即(因为对象是临时的),但即使你遵循建议
kuca(int&b, const string&s) : broj(b), ulica(s) {}
^^^^^
你很容易陷入困境。例如
kuca make_kuca()
{
int x=7;
return {x,"bad"};
}
auto k=make_kuca();
当返回的对象的引用成员引用刚刚超出范围的变量(x
)时。
因此,应谨慎使用参考数据成员,以确保其生命周期永远不会超过他们所指的变量。
答案 2 :(得分:2)
按如下方式更改您的ctor签名:
kuca(int& b, string s) :broj(b)
请注意int&
而不是int
。然后,参数b
将引用变量isbn
而不是某个调用堆栈位置。
应该注意的是原始签名
kuca(int b, string s) : broj(b)
您正在参考堆栈上传递的副本参数。因此,当调用info()方法时,broj
引用调用堆栈上的位置而不是变量isbn
。这就是为什么它似乎打印一个&#34;随机&#34;值。
答案 3 :(得分:0)
您正在存储对参数b
的引用,该参数仅在构造函数调用期间存在。在构造函数调用之后,您将引用一个不存在的int
。
答案 4 :(得分:0)
正如大家已经说过的那样,你可能就是这个......
kuca(int b, string s) :broj(b)
是
kuca(int& b, string s) :broj(b)
通过引用传递int
没有任何性能优势,并且只要int
超出范围可能会导致难以跟踪的错误,引用就无效。
我个人倾向于在变量可以变异时通过地址传递。
class name {
public:
kuca(int* b, string s) : broj(b), ulica(s);
private:
int* broj;
string ulica;
}
将上述内容转换为编译时错误。使用引用作为类成员很容易使用错误。