KSCL::CBinaryClassCaller< type_class, type_1st_parameter, type_2nd_parameter, type_return >のコラボレーション図
公開型 | |
typedef type_return(type_class::* | type_pmfn )(type_1st_parameter, type_2nd_parameter) const |
メンバ関数ポインタの型定義。. より詳しく... | |
公開メンバ | |
CBinaryClassCaller (const type_class &p_rcClass, type_pmfn p_pmfn) | |
・コンストラクタ。. より詳しく... | |
virtual | ~CBinaryClassCaller () |
・デストラクタ。. より詳しく... | |
type_return | operator() (type_1st_parameter p_Lh, type_2nd_parameter p_Rh) const |
・アルゴリズムから呼ばれるメンバ関数。. より詳しく... | |
非公開属性 | |
const type_class & | m_rcClass |
呼び出すクラスへの参照。. より詳しく... | |
type_pmfn | m_pmfn |
呼び出すメンバ関数へのポインタ。. より詳しく... |
引数ふたつ渡されて戻り値を返す関数オブジェクトとして使用できます。
つまり、 operator() の代わりにコンストラクタの引数の (p_rcClass.*p_pmfn)() を呼び出します。
プレディケートで使用することを考えて、メンバ関数は const である必要があります。
まぁ、一種のデリゲートですね。
type_class | 呼び出すクラスの型。 |
type_1st_parameter | アルゴリズムから渡される第1引数の型。 |
type_2nd_parameter | アルゴリズムから渡される第2引数の型。 |
type_return | アルゴリズム内で返す戻り値の型。 |
|
メンバ関数ポインタの型定義。.
|
|
・コンストラクタ。. クラスとメンバ関数を渡してもらいます。
|
|
・デストラクタ。. 特に何もしません。 |
|
・アルゴリズムから呼ばれるメンバ関数。.
|
|
呼び出すクラスへの参照。.
|
|
呼び出すメンバ関数へのポインタ。.
|