I know this might be a common question, and I've seen similar ones asked on SO before. I am trying to wrap my head around that "return by const reference" stuff. I seem to be stuck at this seemingly simple example:
#include <iostream>
using namespace std;
class Test {
public:
int x;
Test(): x(0) {};
const int& getX() const {
return x;
}
};
int main() {
Test t;
int y = t.getX();
cout << y << endl;
t.x = 1;
cout << y << endl; // why not 1?
}
I understand that returning by const int& prevents me from setting t.x using something like y=1
, which is fine. However, I would have expected y to be 1 in the last line, but it remains zero, exactly as if getX() returned a plain int. What exactly is going on here?
While you return by reference, you save the result in the new integer y
that has nothing to do with the member x
from that point on. It is just a copy of t.x
, its value after the point of initialization will not depend on the value or state of existence of t.x
in any way.
Use a reference to observe your desired behavior:
#include <iostream>
using namespace std;
class Test {
public:
int x;
Test(): x(0) {};
const int& getX() const {
return x;
}
};
int main() {
Test t;
const int &y = t.getX();
cout << y << endl;
t.x = 1;
cout << y << endl; // Will now print 1
}