c – 我可以在继承QObject时使用QSharedData吗?

如何在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);
 ..

因此,我可以在继承QObject时使用QSharedData吗?

最佳答案

Thus, can I use QSharedData while inheriting from QObject ?

使用QSharedData时,不能从QObject继承. QSharedData使用copy-on-write语义,并在不再共享数据时调用detach()来创建数据副本.为了进行复制,需要一个QObject不支持的复制构造函数.

pimpl(或handle-body / opaque-pointer成语)通常会为数据类提供对公共实现的引用,这就是您期望使用信号和插槽的方式.

QSharedDataPointer提供了大部分实现细节,但是看一下Qt(see Q_D and friends)中使用的pimpl习语也很有启发性.

点赞