Могу ли я использовать QSharedData при наследовании от QObject? - PullRequest
3 голосов
/ 08 апреля 2010

Как скрыть частную реализацию (неявное совместное использование) в 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, я получаю: ошибка: неправильное использование неполного типа ‘struct EmployeeData’

Однако, если я изменю свое определение на это, оно прекрасно работает:

class Employee
{
public:
    Employee();
    Employee(int id, QString name);
 ..

Таким образом, можно ли использовать QSharedData при наследовании от QObject?

1 Ответ

2 голосов
/ 08 апреля 2010

Таким образом, можно ли использовать QSharedData при наследовании от QObject?

Вы не можете наследовать от QObject при использовании QSharedData. QSharedData использует семантику copy-on-write и вызовет detach () для создания копии данных, когда они больше не передаются. Для выполнения копирования необходим конструктор копирования, который QObject не поддерживает.

pimpl (или идиома непрозрачного-указателя / непрозрачного указателя ) часто дает классу данных ссылку на публичную реализацию, как и ожидается при работе. с сигналами и слотами.

QSharedDataPointer предоставляет большинство деталей реализации, но также весьма поучительно взглянуть на идиому pimpl, используемую в Qt ( смотри Q_D и друзей )

...