C ++类成员通过引用

时间:2015-10-28 22:56:38

标签: c++

你好,有人可以帮我这个吗? 我有一个班级成员参考:

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

5 个答案:

答案 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;
}

将上述内容转换为编译时错误。使用引用作为类成员很容易使用错误。