QScopedPointer Class
template <typename T, typename Cleanup = QScopedPointerDeleter<T>> class QScopedPointerQScopedPointer クラスは、動的に割り当てられたオブジェクトへのポインタを格納し、破棄時にそれを削除します。詳細...
Header: | #include <QScopedPointer> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS Core) target_link_libraries(mytarget PRIVATE Qt6::Core) |
qmake: | QT += core |
Inherited By: |
注意:このクラスの関数はすべてリエントラントです。
パブリック関数
QScopedPointer(T *p = nullptr) | |
~QScopedPointer() | |
T * | data() const |
T * | get() const |
bool | isNull() const |
void | reset(T *other = nullptr) |
bool | operator bool() const |
bool | operator!() const |
T & | operator*() const |
T * | operator->() const |
関連する非会員
bool | operator!=(const QScopedPointer<T, Cleanup> &lhs, const QScopedPointer<T, Cleanup> &rhs) |
bool | operator!=(const QScopedPointer<T, Cleanup> &lhs, std::nullptr_t) |
bool | operator!=(std::nullptr_t, const QScopedPointer<T, Cleanup> &rhs) |
bool | operator==(const QScopedPointer<T, Cleanup> &lhs, const QScopedPointer<T, Cleanup> &rhs) |
bool | operator==(const QScopedPointer<T, Cleanup> &lhs, std::nullptr_t) |
bool | operator==(std::nullptr_t, const QScopedPointer<T, Cleanup> &rhs) |
詳細説明
ヒープに割り当てられたオブジェクトを手作業で管理するのは難しく、エラーが発生しやすい。QScopedPointerは小さなユーティリティクラスで、ヒープ割り当てにスタックベースのメモリ所有権を割り当てることでこれを大幅に簡略化します。
QScopedPointerは、現在のスコープがなくなったときに、指されたオブジェクトが削除されることを保証する。
ヒープ割り当てを行い、さまざまな終了点を持つこの関数を考えてみよう:
void myFunction(bool useSubClass) { MyClass *p = useSubClass ? new MyClass() : new MySubClass; QIODevice *device = handsOverOwnership(); if (m_value > 3) { delete p; delete device; return; } try { process(device); } catch (...) { delete p; delete device; throw; } delete p; delete device; }
この関数はヒープ割り当てを行い、さまざまな終了点を持つ。QScopedPointerを使えば、コードは次のように単純化できる:
void myFunction(bool useSubClass) { // assuming that MyClass has a virtual destructor QScopedPointer<MyClass> p(useSubClass ? new MyClass() : new MySubClass); QScopedPointer<QIODevice> device(handsOverOwnership()); if (m_value > 3) return; process(device); }
コンパイラがQScopedPointer用に生成するコードは、手動で記述する場合と同じです。delete を使用するコードは、QScopedPointer を使用する候補です(使用しない場合は、QSharedPointer などの別のタイプのスマート・ポインタを使用することもできます)。QScopedPointerは、所有権と寿命が明確に伝達されるように、意図的にコピーコンストラクタや代入演算子を持ちません。
通常の C++ ポインタの const 修飾も QScopedPointer で表現できます:
const QWidget *const p = new QWidget(); // is equivalent to: const QScopedPointer<const QWidget> p(new QWidget()); QWidget *const p = new QWidget(); // is equivalent to: const QScopedPointer<QWidget> p(new QWidget()); const QWidget *p = new QWidget(); // is equivalent to: QScopedPointer<const QWidget> p(new QWidget());
カスタム・クリーンアップ・ハンドラ
配列や、malloc
で割り当てられたポインタは、delete
を使用して削除してはいけません。QScopedPointerの2番目のテンプレート・パラメータは、カスタム・クリーンアップ・ハンドラに使用できます。
以下のカスタム・クリーンアップ・ハンドラがあります:
- QScopedPointerDeleter - デフォルト。
delete
- QScopedPointerArrayDeleter -
delete []
を使用してポインタを削除します。このハンドラは、new []
で割り当てられたポインタに使用します。 - QScopedPointerPodDeleter -
free()
を使用してポインタを削除します。malloc()
で割り当てられたポインタには、このハンドラを使用してください。 - QScopedPointerDeleteLater - ポインタに対して
deleteLater()
を呼び出してポインタを削除します。このハンドラは、QEventLoop にアクティブに参加しているQObject へのポインタに使用します。
独自のクラスをハンドラとして渡すこともできます。ただし、そのクラスがパブリックな静的関数void cleanup(T *pointer)
を持っていることが条件です。
// this QScopedPointer deletes its data using the delete[] operator: QScopedPointer<int, QScopedPointerArrayDeleter<int> > arrayPointer(new int[42]); // this QScopedPointer frees its data using free(): QScopedPointer<int, QScopedPointerPodDeleter> podPointer(reinterpret_cast<int *>(malloc(42))); // this struct calls "myCustomDeallocator" to delete the pointer struct ScopedPointerCustomDeleter { static inline void cleanup(MyCustomClass *pointer) { myCustomDeallocator(pointer); } }; // QScopedPointer using a custom deleter: QScopedPointer<MyCustomClass, ScopedPointerCustomDeleter> customPointer(new MyCustomClass);
前方宣言ポインタ
前方宣言されたクラスは、QScopedPointerのクリーンアップが必要なときに前方宣言されたクラスのデストラクタが利用可能である限り、QScopedPointer内で使用することができます。
具体的には、前方宣言されたクラスを指す QScopedPointer を含むすべてのクラスは、非インラインのコンストラクタ、デストラクタ、および代入演算子を持たなければなりません:
class MyPrivateClass; // forward declare MyPrivateClass class MyClass { private: QScopedPointer<MyPrivateClass> privatePtr; // QScopedPointer to forward declared class public: MyClass(); // OK inline ~MyClass() {} // VIOLATION - Destructor must not be inline private: Q_DISABLE_COPY(MyClass) // OK - copy constructor and assignment operators // are now disabled, so the compiler won't implicitly // generate them. };
そうでない場合、コンパイラーはMyPrivateClass
をデストラクトできないという警告を出力します。
QSharedPointerも参照してください 。
メンバ関数のドキュメント
[explicit noexcept]
QScopedPointer::QScopedPointer(T *p = nullptr)
この QScopedPointer インスタンスを構築し、そのポインタをp に設定します。
QScopedPointer::~QScopedPointer()
このQScopedPointer オブジェクトを破棄します。そのポインタが指すオブジェクトを削除します。
[noexcept]
T *QScopedPointer::data() const
このオブジェクトによって参照されるポインタの値を返します。QScopedPointer は、ポインタが指すオブジェクトをまだ所有しています。
[noexcept]
T *QScopedPointer::get() const
data() と同じ。
[noexcept]
bool QScopedPointer::isNull() const
このオブジェクトがnullptr
を参照している場合はtrue
を返す。
[noexcept(...)]
void QScopedPointer::reset(T *other = nullptr)
指している既存のオブジェクトを削除し(もしあれば)、そのポインタをother に設定します。QScopedPointer はother を所有することになり、そのデストラクタで削除されます。
注意: この関数は、"noexcept(Cleanup::cleanup(std::declar<T *>()))" が true の場合、例外をスローしません。
[explicit]
bool QScopedPointer::operator bool() const
含まれるポインタがnullptr
でない場合はtrue
を返します。この関数はif-constructs
のような用途に適している:
if (scopedPointer) { ... }
isNull()も参照 。
[noexcept]
bool QScopedPointer::operator!() const
このオブジェクトがnullptr
を参照している場合はtrue
を返す。
isNull() も参照 。
T &QScopedPointer::operator*() const
スコープされたポインタのオブジェクトへのアクセスを提供します。
含まれるポインタがnullptr
の場合、動作は未定義です。
isNull()も参照して ください。
[noexcept]
T *QScopedPointer::operator->() const
スコープされたポインタのオブジェクトへのアクセスを提供します。
含まれるポインタがnullptr
の場合、動作は未定義です。
isNull() も参照 。
関連する非メンバー
[noexcept]
bool operator!=(const QScopedPointer<T, Cleanup> &lhs, const QScopedPointer<T, Cleanup> &rhs)
lhs とrhs が異なるポインタを参照している場合はtrue
を返す。
[noexcept]
bool operator!=(const QScopedPointer<T, Cleanup> &lhs, std::nullptr_t)
lhs が有効な(つまり NULL ではない)ポインタを参照している場合はtrue
を返す。
QScopedPointer::isNull()も参照 。
[noexcept]
bool operator!=(std::nullptr_t, const QScopedPointer<T, Cleanup> &rhs)
rhs が有効な(つまり NULL ではない)ポインタを指している場合はtrue
を返す。
QScopedPointer::isNull()も参照の こと。
[noexcept]
bool operator==(const QScopedPointer<T, Cleanup> &lhs, const QScopedPointer<T, Cleanup> &rhs)
lhs とrhs が同じポインタを指している場合はtrue
を返す。
[noexcept]
bool operator==(const QScopedPointer<T, Cleanup> &lhs, std::nullptr_t)
lhs がnullptr
を参照している場合はtrue
を返す。
QScopedPointer::isNull()も参照 。
[noexcept]
bool operator==(std::nullptr_t, const QScopedPointer<T, Cleanup> &rhs)
rhs がnullptr
を参照している場合はtrue
を返す。
QScopedPointer::isNull()も参照の こと。
©2024 The Qt Company Ltd. 本書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。