我们在之前的博文QVector的内存分配策略 与再谈QVector与std::vector——使用装饰者让std::vector支持连续赋值中简单聊了聊QVector内存分配和赋值方面的一点东西,今天接着从QVector展开谈谈Qt的写时复制技术。老实说,“隐式共享,引用计数,写时复制”也是老调重弹的话题了,不过也是QTL与STL最大的区别之一,这篇博文不详谈“写时复制”技术的细节,那个有不少文章介绍过了,我们扯点关于operator[]和QByteRef和QStringRef的犊子就好。
废话不多说,直接进主题,我们先从一段最普通的代码开始:
QVector<int> v1;
v1 << 1 << 2 << 3 << 4 << 5;
QVector<int> v2(v1); // 此时v2与v1共享数据(内存)
v2[1] = 8; // 写动作产生,v2被分配新内存
qDebug() << v1 << endl << v2;
利用"写时复制"技术,v1“复制”给v2时并没有立刻复制,v2只是指向v1的内存地址,只有当v2被修改时才真正为其分配新的内存。 这样可以避免一些不必要的内存浪费和构造析构开销。得益于Qt良好的封装,即使我们不知道这一切,依然享受着“写时复制”机制带给我们的好