为什么我能够创建一个复制构造函数并重载QObject子类的赋值运算符?

时间:2010-06-19 05:54:20

标签: c++ qt qobject

我的印象是QObject禁用了复制构造函数和赋值运算符...为什么我能够编译包含这两者的QObject派生?

#ifndef QVERSION_H
#define QVERSION_H

#include "silverlocklib_global.h"
#include <QtCore>

struct SILVERLOCKLIBSHARED_EXPORT QVersion : public QObject
{
    Q_OBJECT
    Q_PROPERTY(bool valid READ isValid)
    Q_PROPERTY(long major READ major)
    Q_PROPERTY(long minor READ minor)
    Q_PROPERTY(long build READ build)
    Q_PROPERTY(long revision READ revision)

public:
    QVersion(long major = 0, long minor = 0, long build = -1, long revision = -1, QObject *parent = NULL);
    QVersion(const QString &version, QObject *parent = NULL);
    QVersion(const QVersion &version);
    static QVersion parse(const QString& version, bool *ok = NULL);
    bool isValid() const;
    long compareTo(const QVersion &other) const;
    bool equals(const QVersion &other) const;
    QString toString() const;
    QString toString(int fieldCount) const;
    long major() const;
    inline int majorRevision() const { return (qint16)(this->m_revision >> 16); }
    long minor() const;
    inline int minorRevision() const { return (qint16)(this->m_revision & 65535); }
    long build() const;
    long revision() const;
    QVersion& operator=(const QVersion &version);
    friend bool operator==(const QVersion &v1, const QVersion &v2);
    friend bool operator!=(const QVersion &v1, const QVersion &v2);
    friend bool operator<(const QVersion &v1, const QVersion &v2);
    friend bool operator<=(const QVersion &v1, const QVersion &v2);
    friend bool operator>(const QVersion &v1, const QVersion &v2);
    friend bool operator>=(const QVersion &v1, const QVersion &v2);

private:
    inline static void copy(QVersion *const destination, const QVersion &source);
    static bool tryParseComponent(const QString &component, long *parsedComponent);

    long m_major;
    long m_minor;
    long m_build;
    long m_revision;
};

#endif // QVERSION_H

2 个答案:

答案 0 :(得分:6)

派生类总是可以声明它自己的复制构造函数和赋值运算符。如果基类通过将其设为私有来禁用它并使其未定义,则派生类当然不能在其自己的实现中调用基类的版本,但它仍然可以实现它们。

答案 1 :(得分:1)

正如Omnifarious的回答一样。正如他所说,您可以实现派生类的复制构造函数,但是您将无法使用基类'复制构造函数来初始化基类中的数据成员。

如果没有指定初始化基类数据成员的构造函数,编译器将使用基类'default constructor。