背景
Qt 中的许多类都是使用隐式共享来最大化资源使用并最小化复制。其进行参数传递时采用浅拷贝方式,只传递指向数据的指针,并且只有在数据写入时才真的拷贝数据。
通过使用 Qt 提供的相关类,可以实现自定义的隐式共享类。
Qt 中的隐式共享
①.概述
Qt 中的 QString 是具有隐式共享特性的类。
②.代码示例
QString s1 = "hello world";
QString s2 = s1;
qDebug() << s1.constData();
qDebug() << s2.constData();
如上图所示,s1 和 s2 中包含的数据指向同一个地址,但如果一个字符串发生更改时,将会进行写时拷贝操作:
QString s1 = "hello world";
QString s2 = s1;
qDebug() << s1.constData();
qDebug() << s2.constData();
s2[0] = 'H';
qDebug() << "s2 更改后:";
qDebug() << s1.constData();
qDebug() << s2.constData();
隐式共享相关类
①.概述
Qt 提供了一套包含隐式共享机制的一些类。
②.QSharedData
QSharedData 是实现共享数据对象的基类。
③.QSharedDataPoint
QSharedDataPoint 是一个模板类,和 QSharedData 一起使用来实现隐式数据共享。
自定义隐式共享类
①.概述
使用 QSharedData 和 QSharedDataPoint 可以实现自定义的隐式共享类。
②.代码示例
struct demoClassData :public QSharedData
{
demoClassData(){}
demoClassData(int m_id,const QString &m_name) :id(m_id), name(m_name){}
int id{-1};
QString name;
};
class demoClass
{
public:
demoClass():d(new demoClassData){}
demoClass(int m_id, const QString &m_name):d(new demoClassData(m_id, m_name)) {}
void setId(int m_id) { d->id = m_id; }
void setName(const QString &m_name) { d->name = m_name; }
void printData() { qDebug() << d.constData(); }
private:
QSharedDataPointer<demoClassData> d;
};
demoClass d1(1, "aaaa");
demoClass d2 = d1;
d1.printData();
d2.printData();
d2.setName("bbbb");
qDebug() << "数据修改后";
d1.printData();
d2.printData();