Могу ли я использовать QSharedData при наследовании от QObject?
Как скрыть частную реализацию (неявное совместное использование) в Qt:
В заголовке Employee.h у меня есть Employee.cpp:
#include <QSharedData>
#include <QString>
class EmployeeData;
class Employee: public QObject
{
Q_OBJECT
public:
Employee();
Employee(int id, QString name);
Employee(const Employee &other);
void setId(int id);
void setName(QString name);
int id();
QString name();
private:
QSharedDataPointer<EmployeeData> d;
};
class EmployeeData : public QSharedData
{
public:
EmployeeData() : id(-1) { name.clear(); }
EmployeeData(const EmployeeData &other)
: QSharedData(other), id(other.id), name(other.name) { }
~EmployeeData() { }
int id;
QString name;
};
Но когда я перемещаю EmployeeData в приватную часть, скажем Employee.cpp, я получаю: error: недопустимое использование неполного типа 'struct EmployeeData'
Однако, если я изменю свое определение на это, оно будет работать нормально:
class Employee
{
public:
Employee();
Employee(int id, QString name);
..
Таким образом, я могу использовать QSharedData при наследовании от QObject?
1 ответ
Таким образом, я могу использовать QSharedData при наследовании от QObject?
Вы не можете наследовать от QObject при использовании QSharedData. QSharedData использует семантику копирования при записи и будет вызывать detach() для создания копии данных, когда они больше не передаются. Чтобы сделать копию, нужен конструктор копирования, который QObject не поддерживает.
Pimpl (или идиома handle-body / opaque-pointer) часто дает классу данных ссылку на общедоступную реализацию, которая, как вы ожидаете, будет работать с сигналами и слотами.
QSharedDataPointer предоставляет большинство деталей реализации, но также весьма поучительно взглянуть на идиому pimpl, используемую в Qt ( см. Q_D и его друзья)