我有一个类,它有一些我希望从调用者隐藏的数据成员(因为包含其类型的标题会显着增加编译时间,并且它需要使用此类的每个项目添加一个额外的路径到他们的包含路径)。
此类使用QSharedDataPointer
来存储此数据。这样就可以使用默认的复制构造函数进行复制。
这个类的基本结构是:
class MyClass {
private:
QSharedDataPointer<MySharedClassData> m_data;
};
是否有任何花哨的技巧来执行此操作没有在同一个头文件中定义MySharedClassData
(继承自QSharedData
)?或者还有其他隐藏数据字段的好方法吗?
我已经尝试了MySharedClassData
的前瞻声明,但这不起作用(尽管m_data
是private
)。
我目前可以解决的唯一解决方案是将m_data
声明为QSharedDataPointer<QSharedData>
但是每次我想要访问它时都需要转换数据成员。有更好的解决方案吗?
答案 0 :(得分:6)
只要未在头文件中定义构造函数和析构函数,前向声明就应该正常工作。以下类在我的计算机上编译:
#ifndef MAIN_WINDOW_HXX
#define MAIN_WINDOW_HXX
#include <QMainWindow>
#include <ui_MainWindow.h>
#include <QSharedDataPointer>
class MySharedClassData;
class MainWindow : public QMainWindow, private Ui_MainWindow {
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0, Qt::WindowFlags flags = 0);
virtual ~MainWindow();
QSharedDataPointer<MySharedClassData> m_data;
};
#endif
如果您尝试内联构造函数/析构函数,那么您可能会在VS下收到:C2027: use of undefined type 'type'
。
答案 1 :(得分:0)
是。没有必要真正花哨的技巧。但是,所有做需要MySharedClassData
的方法必须在MySharedClassData
的定义之后定义。如果将类定义移动到.cpp文件,则必须将方法移动到那里。
答案 2 :(得分:0)
一般情况下,如果你想使用带有指向前向声明impl的智能指针的pimpl习惯用法(而不是手动管理impl对象),你需要一个带有脱线删除器的智能指针,如{ {1}}(您应该可以将boost::shared_ptr
与自定义删除器一起使用,但我还没有尝试过。)
要求是您可以在不看到impl类析构函数的情况下实例化智能指针模板:例如,这会排除std::unique_ptr
。
我不知道std::auto_ptr
是否符合要求,但tibur似乎表示确实如此。