大佬教程收集整理的这篇文章主要介绍了c – 移动语义和const引用,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
好的,所以我有这个对象在堆上有很多数据:我实现了移动语义的CLargeOb(构造函数和运算符=).它的理想用途如下:
void OtherOb::Func(CLargeOb&& largeOb1,CLargeOb&& largeOb2) { SomeOtherFunc(largeOb1); // use objects SomeOtherFunc(largeOb2); m_largeOb1 = (CLargeOb&&)largeOb1; // save as members and trash the originals m_largeOb2 = (CLargeOb&&)largeOb2; }
但是,并不总是允许移动/删除对象,所以我添加了这两个函数:
void OtherOb::Func(const cLargeOb& largeOb1,CLargeOb&& largeOb2) { SomeOtherFunc(largeOb1); SomeOtherFunc(largeOb2); m_largeOb1 = largeOb1; m_largeOb2 = (CLargeOb&&)largeOb2; } void OtherOb::Func(CLargeOb&& largeOb1,const cLargeOb& largeOb2) { SomeOtherFunc(largeOb1); SomeOtherFunc(largeOb2); m_largeOb1 = (CLargeOb&&)largeOb1; m_largeOb2 = largeOb2; }
虽然它有效,你已经可以猜到当我有一个函数将这些对象中的3个或更多作为参数时,它将成为* ss中的一个主要痛苦…是不是有一种聪明的方法来解决这个使用模板或者也许’完美转发’?
这让调用者可以处理如何获取对象,只需获得一个对象:
void OtherOb::Func(CLargeOb largeOb1,CLargeOb largeOb2) { SomeOtherFunc(largeOb1); // use objects SomeOtherFunc(largeOb2); m_largeOb1 = std::move(largeOb1); // save as members and trash the originals m_largeOb2 = std::move(largeOb2); // (you should use std::move,not cast) }
呼叫者,召集者:
OtherOb o; CLargeOb x,y; const cLargeOb z; o.Func(x,std::move(y)); // need x for later,done with y so move it o.Func(std::move(X),z); // done with x,necessarily copy z
这与几个专门的重载一样有效.为什么?因为那些已经存在于类中的构造函数.让编译器为你找出在呼叫站点调用的内容,它已经知道该怎么做了.
以上是大佬教程为你收集整理的c – 移动语义和const引用全部内容,希望文章能够帮你解决c – 移动语义和const引用所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。