Главная · Все классы · Основные классы · Классы по группам · Модули · Функции

Классы с неявным разделением данных

Many C++ classes in Qt use implicit data sharing to maximize resource usage and minimize copying of data. The only important effect is that the classes listed here can be passed around as arguments efficiently, even though they may seem heavyweight.

Краткий обзор

A shared class consists of a pointer to a shared data block that contains a reference count and the data.

When a shared object is created, it sets the reference count to 1. The reference count is incremented whenever a new object references the shared data, and decremented when the object dereferences the shared data. The shared data is deleted when the reference count becomes zero.

When dealing with shared objects, there are two ways of copying an object. We usually speak about deep and shallow copies. A deep copy implies duplicating an object. A shallow copy is a reference copy, i.e. just a pointer to a shared data block. Making a deep copy can be expensive in terms of memory and CPU. Making a shallow copy is very fast, because it only involves setting a pointer and incrementing the reference count.

Object assignment (with operator=()) for implicitly shared objects is implemented using shallow copies.

The benefit of sharing is that a program does not need to duplicate data unnecessarily, which results in lower memory use and less copying of data. Objects can easily be assigned, sent as function arguments, and returned from functions.

Implicit sharing takes place behind the scenes; the programmer does not need to worry about it. Even in multithreaded applications, implicit sharing takes place, as explained in Threads and Implicit Sharing.

Implicit Sharing in Detail

Implicit sharing automatically detaches the object from a shared block if the object is about to change and the reference count is greater than one. (This is often called "copy-on-write" or "value semantics".)

An implicitly shared class has total control of its internal data. In any member functions that modify its data, it automatically detaches before modifying the data.

The QPen class, which uses implicit sharing, detaches from the shared data in all member functions that change the internal data.

Code fragment:

 void QPen::setStyle(Qt::PenStyle style)
 {
     detach();           // detach from common data
     d->style = style;   // set the style member
 }

 void QPen::detach()
 {
     if (d->ref != 1) {
         ...             // perform a deep copy
     }
 }

List of Classes

The classes listed below automatically detach from common data if an object is about to be changed. The programmer will not even notice that the objects are shared. Thus you should treat separate instances of them as separate objects. They will always behave as separate objects but with the added benefit of sharing data whenever possible. For this reason, you can pass instances of these classes as arguments to functions by value without concern for the copying overhead.

Пример:

 QPixmap p1, p2;
 p1.load("image.bmp");
 p2 = p1;                        // p1 and p2 share data

 QPainter paint;
 paint.begin(&p2);               // cuts p2 loose from p1
 paint.drawText(0,50, "Hi");
 paint.end();

In this example, p1 and p2 share data until QPainter::begin() is called for p2, because painting a pixmap will modify it.

Warning: Do not copy an implicitly shared container (QMap, QVector, etc.) while you are iterating over it using an non-const STL-style iterator.

QBitArrayБитовый массив
QBitmapМонохромное (глубина в 1 бит) растровое изображение
QBrushОпределяет образец заливки фигур, отображаемых с помощью QPainter
QByteArrayБайтовый массив
QCacheКласс-шаблон, реализующий кэш
QCursorУказатель мыши произвольной формы
QDirДоступ к структуре каталогов и их содержимому
QFileInfoНезависимая от системы информация о файле
QFontУстанавливает шрифт, используемый для отрисовки текста
QFontInfoОбщая информация о шрифтах
QFontMetricsИнформация о метриках шрифта
QFontMetricsFИнформация о метриках шрифта
QGLColormapИспользуется для установки собственных цветовых карт в QGLWidgets
QGradientИспользуется совместно с QBrush для задания градиентной заливки
QHashКласс-шаблон для представления словаря, основанного на хэш-таблице
QIconМасштабируемые пиктограммы для различных режимов и состояний
QImageАппаратно-независимое представление изображения, предоставляющее прямой доступ к пикселям и способная работать в качестве устройства рисования
QKeySequenceСодержит последовательность клавиш, используемую как горячие клавиши
QLinkedListКласс-шаблон, реализующий связанный список
QListКласс-шаблон, реализующий связанный список
QLocaleКонвертирует числа в их строковые представления на различных языках
QMapКласс-шаблон, реализующий список, основанный на словаре
QMultiHashВспомогательный подкласс QHash, предоставляющий хэширование нескольких значений
QMultiMapВспомогательный подкласс QMap, предоставляющий карты с несколькими значениями
QPaletteСодержит цветовые группы для каждого состояния виджета
QPenЗадает для QPainter способ рисования линий и контуров фигур
QPictureУстройство рисования, запоминающее и повторяющее команды QPainter
QPixmapНеэкранное представление изображения, которое может использоваться в качестве устройства рисования
QPolygonВектор точек с координатами, заданными целыми числами
QPolygonFВектор точек с координатами, заданными числами с плавающей точкой
QQueueОбщий контейнер, реализующий очередь
QRegExpПроверка соответствия используемому регулярному выражению
QRegionУстанавливает область отсечения для рисовальщика (painter)
QSetКласс-шаблон набора, основанного на хэшированной таблице
QSqlFieldУправление полями в таблицах и представлениях базы данных SQL
QSqlQueryСредства управления выражениями SQL и их выполнения
QSqlRecordЗаключает в себе запись базы данных
QStackКласс-шаблон стека
QStringСтрока символов Unicode
QStringListСписок строк
QTextCursorПредлагает API для доступа к объектам QTextDocument и изменению их содержимого
QTextDocumentFragmentПредставляет фрагмент форматированного текста из QTextDocument
QTextFormatИнформация о форматировании в QTextDocument
QUrlВспомогательный интерфейс для работы с адресами URL
QVariantДействует аналогично объединению для большинства общих типов данных Qt
QVectorКласс-шаблон, представляющий динамический массив
QX11InfoИнформация о конфигурации X-дисплея


Copyright © 2008 Trolltech Торговые марки
Qt 4.3.5