class A { public: int m_a; A() : m_a(0) { std::cout << "A()" << std::endl; } A(const A& other) : m_a(other.m_a) { std::cout << "A(const A&)" << std::endl; } int& get_a() { return m_a; } A& get_class() { return (*this); } };
void solve() { A _A; auto t = _A.get_class(); t.m_a = 2; std::cout << _A.m_a << std::endl; }
output: A() A(const A&) 0
从output可以看出,auto 自动推导了 A t = _A.get_class(),故调用了class A的拷贝构造函数
void solve() { A _A; auto& t = _A.get_class(); t.m_a = 2; std::cout << _A.m_a << std::endl; }
output: A() 2
可以看出 auto& 推导出了 A& t = _A.get_class(),这样我们就知识对返回的实例引用的操作,节省了额外的开销
总结,对于 auto 的使用,我们得注意是否加&或者在该情况下auto可能推导出的类型是不是会重新拷贝一个副本而导致内存的申请
A& get_class() const { return (*this); // const A* const this } 错误 C2440 “return”: 无法从“const A”转换为“A &” const A& get_class() const { return (*this); } 正确