隐式共享机制(implicit sharing),也叫做copy on write。顾名思义,就是说,在内容有变动的情况下才对容器中的数据结构做复制,否则仅做共享。QT中所有的容器类都支持隐式共享,而无论是Java风格还是STL风格的迭代器,使用只读迭代器时,背后也都使用到了隐式共享机制,以增加读取的效率。比如:QList
int main(int argc, char *argv[])
{
QList<QString> list1;
list1<<"test";
QList<QString> list2=list1;
qDebug()<<&list1.at(0);
qDebug()<<&list2.at(0);
//qDebug()<<&list1[0]; //[]运算
//qDebug()<<&list2[0]; //[]运算
list2<<"tests";
qDebug()<<&list1.at(0);
qDebug()<<&list2.at(0);
QList<QString> list=copyOnWrite();
qDebug()<<&list;
qDebug()<<&list.at(0);
}
QList<QString> copyOnWrite()
{
QList<QString> list;
list<<"str1"<<"str2";
///...
qDebug()<<&list;
qDebug()<<&list.at(0);
return list;
}
比如以上示例有以下输出:
0x123ed4c
0x123ed4c
0x123ed4c
0x151926c
0x25f7ac
0x15180dc //list.at(0)
0x25f828
0x15180dc //list.at(0)
1. 网上都说是copyOnWrite函数体内&list地址与主函数中&list地址是一样的,结果却是不一致的,但元素地址是一致的,难道错了。
2. 使用[]运算,数据结构经过复制,不再隐式共享。(在只读的情况下,使用at()方法要比使用[]运算子效率高,因为省去了数据结构的复制成本)。