大佬教程收集整理的这篇文章主要介绍了c – 使用指向内部缓冲区的指针移动语义,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
class Foo { public: Foo(); ... private: std::vector<unsigned char> m_buffer; unsigned char* m_pointer; }; Foo::Foo() { m_buffer.resize(100); m_pointer = &m_buffer[0]; }
现在,假设我也正确实现了3规则的东西,包括复制内部缓冲区的复制构造函数,然后将指针重新分配给内部缓冲区的新副本:
Foo::Foo(const Foo& f) { m_buffer = f.m_buffer; m_pointer = &m_buffer[0]; }
如果我还实现了移动语义,那么只复制指针并移动缓冲区是否安全?
Foo::Foo(Foo&& f) : m_buffer(std::move(f.m_buffer)),m_pointer(f.m_pointer) { }
在实践中,我知道这应该工作,因为Std :: vector移动构造函数只是移动内部指针 – 它实际上并没有重新分配任何东西,所以m_pointer仍然指向一个有效的地址.但是,我不确定标准是否可以保证这种行为. std :: vector移动语义是否保证不会发生重新分配,因此向量的所有指针/迭代器都是有效的?
以上是大佬教程为你收集整理的c – 使用指向内部缓冲区的指针移动语义全部内容,希望文章能够帮你解决c – 使用指向内部缓冲区的指针移动语义所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。