SophiaFramework UNIVERSE 5.3 |
#include <SFXResponderPointer.h.hpp>
class SFXResponderPointer;
SFMTYPEDEFCLASS(SFXResponderPointer)
SFXResponderPointer クラスは、 参照カウントオブジェクトクラスに対して、参照カウントを自動管理する機能を提供します。
コンストラクタ/デストラクタ |
---|
SFXResponderPointer( Void ) SFXResponderPointer クラスのコンストラクタです。
|
SFXResponderPointer(
SFXResponderPointer< M > const & param
) SFXResponderPointer クラスのコンストラクタです。
|
SFXResponderPointer(
SFXResponderPointer< T > const & param
) SFXResponderPointer クラスのコンストラクタです。
|
SFXResponderPointer(
T * pointer
, Bool increment = true
) SFXResponderPointer クラスのコンストラクタです。
|
[ public, explicit ] SFXResponderPointer(Void);
[ public ] SFXResponderPointer( SFXResponderPointer< M > const & param // コピーする SFXResponderPointer のリファレンス );
[ public ] SFXResponderPointer( SFXResponderPointer< T > const & param // コピーする SFXResponderPointer のリファレンス );
[ public, explicit ] SFXResponderPointer( T * pointer // 格納するインスタンスのポインタ Bool increment = true // 参照カウンタを増加させるかどうかを指定する );
このコンストラクタは、 指定されたインスタンスを設定します。
注意 | |
---|---|
引数が SFXResponderPointer インスタンスの場合は、コピーされます。 デフォルトでは、 設定するインスタンスの参照カウンタはインクリメントされます。 |
[ public ] Void Attach( T * pointer // 解放責任を譲るインスタンスのポインタ );
この関数は、指定されたインスタンスの解放責任を受けます。
注意 | |
---|---|
SFXResponderPointer クラスが解放責任を受けると、 SFXResponderPointer クラスがインスタンスを管理するようになり、 参照カウントの自動管理が行われます。 |
Attach 関数は
SFXResponderPointer::Set(address, false);
を実行するのと同じです。
[ public ] T * Detach(Void);
SFXResponderPointer クラスが内部に保持しているインスタンス。
この関数は、 SFXResponderPointer クラスが内部に保持しているインスタンスの解放責任を譲ります。
注意 | |
---|---|
SFXResponderPointer クラスは内部で保持していたインスタンスを管理しなくなり、 参照カウントの自動管理が行われなくなります。 |
[ public, static ] SFXResponderPointer< T > const & EmptyInstance(Void);
null を表す SFXResponderPointer インスタンスのリファレンス。
この関数は、 null を表す SFXResponderPointer インスタンスを取得します。
注意 | |
---|---|
この関数を利用すれば、 null を表す SFXResponderPointer インスタンスの const 参照を返すことができます。 |
この関数の内部実装は以下の通りです。
template <typename T> /*public static */inline SFXResponderPointer<T> const& SFXResponderPointer<T>::EmptyInstance(Void) { return static_cast<SFXResponderPointer<T> const&>(SFAResponderPointer::EmptyInstance()); }// SFXResponderPointer<T>::EmptyInstance // /*protected static */SFAResponderPointerConstRef SFAResponderPointer::EmptyInstance(Void) { static UInt64Const result[cluster64of(SFAResponderPointer)] = { 0 }; return *reinterpret_cast<SFAResponderPointerConstPtr>(result); }// SFAResponderPointer::EmptyInstance //
cluster64of マクロ | |
---|---|
cluster64of マクロは、 8 バイト境界にアラインしたときに 8 バイトのクラスターがいくつ必要になるかを計算するマクロです。 |
[ public, const ] T * Get(Void);
保持しているインスタンスのポインタ。
この関数は、 保持しているインスタンスのポインタを取得します。
[ public ] Void Release(Void);
この関数は、 内部に保持しているインスタンスを解放します。
注意 | |
---|---|
SFXResponderPointer クラスが内部に保持しているインスタンスの参照カウンタをデクリメントし、 インスタンスの管理をしなくなります。 |
[ public ] Void Set( SFXResponderPointer< M > const & param // 設定する SFXResponderPointer のリファレンス );
[ public ] Void Set( SFXResponderPointer< T > const & param // 設定する SFXResponderPointer のリファレンス );
[ public ] Void Set( T * pointer // 格納するインスタンスのポインタ Bool increment = true // 参照カウンタを増加させるかどうか );
この関数は、 指定されたインスタンスを設定します。
注意 | |
---|---|
旧いインスタンスの参照カウンタをデクリメントしてから、 新しいインスタンスのポインタを設定します。 デフォルトでは、 新しいインスタンスの参照カウンタはインクリメントされます。 |
SFXResponderPointer::Get | SFXResponderPointer::SFXResponderPointer | SFXResponderPointer::operator=
SFXResponderPointer< T > const_pointer_cast( SFXResponderPointer< M > const & param // キャストするポインタ );
この関数は、 SFXResponderPointer 同士で const_cast を行います。
注意 | |
---|---|
SFXResponderPointer 同士の const_cast は、 const_pointer_cast 関数を使用して行います。 |
SFXResponderPointer< T > reinterpret_pointer_cast( SFXResponderPointer< M > const & param // キャストするポインタ );
この関数は、 SFXResponderPointer 同士で reinterpret_cast を行います。
注意 | |
---|---|
SFXResponderPointer 同士の reinterpret_cast は、 reinterpret_pointer_cast 関数を使用して行います。 |
SFXResponderPointer< T > static_pointer_cast( SFXResponderPointer< M > const & param // キャストするポインタ );
この関数は、 SFXResponderPointer 同士で static_cast を行います。
注意 | |
---|---|
SFXResponderPointer 同士の static_cast は、 static_pointer_cast 関数を使用して行います。 |
[ public, const ] T * operator->(Void);
保持しているインスタンスのポインタ。
このオペレータは、 保持しているインスタンスのメンバにアクセスします。
-> オペレータのオーバーロード | |
---|---|
オーバーロードされた -> オペレータでは、 戻り値に対して事前定義された -> オペレータが更に作用されます。 SFXResponderPointer::Get 関数は保持しているインスタンスのポインタを返すだけですが、 SFXResponderPointer::operator-> オペレータは保持しているインスタンスのポインタを取得し、 更に事前定義された -> オペレータを呼び出し、 保持しているインスタンスのメンバにアクセスします。 |
[ public ] SFXResponderPointer< T > & operator=( SFXResponderPointer< M > const & param // 代入する SFXResponderPointer のリファレンス );
[ public ] SFXResponderPointer< T > & operator=( SFXResponderPointer< T > const & param // 代入する SFXResponderPointer のリファレンス );
[ public, friend ] Bool operator==( SFXResponderPointer< T > const & left // 比較する SFXResponderPointer のリファレンス SFXResponderPointer< M > const & right // 比較する SFXResponderPointer のリファレンス );
[ public, friend ] Bool operator==( SFXResponderPointer< T > const & left // 比較する SFXResponderPointer のリファレンス SFYResponderConstPtr right // 比較する SFYResponder のポインタ );
[ public, friend ] Bool operator==( SFYResponderConstPtr left // 比較する SFYResponder のポインタ SFXResponderPointer< T > const & right // 比較する SFXResponderPointer のリファレンス );
このオペレータは、 == の関係を判定します。
[ const ] T & operator*(Void);
保持しているインスタンス。
このオペレータは、 保持しているインスタンスを取得します。
[ public, friend ] Bool operator!=( SFXResponderPointer< T > const & left // 比較する SFXResponderPointer のリファレンス SFXResponderPointer< M > const & right // 比較する SFXResponderPointer のリファレンス );
[ public, friend ] Bool operator!=( SFXResponderPointer< T > const & left // 比較する SFXResponderPointer のリファレンス SFYResponderConstPtr right // 比較する SFYResponder のポインタ );
[ public, friend ] Bool operator!=( SFYResponderConstPtr left // 比較する SFYResponder のポインタ SFXResponderPointer< T > const & right // 比較する SFXResponderPointer のリファレンス );
このオペレータは、 == の関係を判定します。
Copyright(c) 2002 - 2024 Sophia Cradle Incorporated All Rights Reserved. |