标签:const cout get auto 细节 关于 return class
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); } 正确
标签:const,cout,get,auto,细节,关于,return,class 来源: https://www.cnblogs.com/SSummerZzz/p/15831717.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。