write_once_node テンプレート・クラス

概要

graph_nodereceiver<Input>sender<Output> のテンプレート・クラス。write_once_node は、上書きできない 1 つのアイテムのバッファーです。

構文

template < typename T > class write_once_node;

ヘッダー

#include "tbb/flow_graph.h"

説明

このノードは、T 型の 1 つのアイテムをバッファーに格納します。値は最初は無効です。ノードの最初の try_put は、内部バッファーの値を設定して、新しい値をすべてのサクセサーにブロードキャストします。後続の put は無視され、受け取った値は失われます。内部バッファーが明示的にクリアされた後に、新しい値が設定されます。ノードから取得した値は破棄されません。内部バッファーの値が有効な場合、try_gettrue を返し、バッファーの値を出力にコピーします。内部バッファーの値が無効な場合、try_getfalse を返します。

サクセサーがメッセージを拒否した場合、「メッセージ・パッシング・プロトコル」で説明されているプロトコルを使用して処理されます。

T は、コピー構築可能および代入可能でなければなりません。

メンバー

namespace tbb {
namespace flow {
 
template< typename T >
class write_once_node :
  public graph_node, public receiver<T>,
  public sender<T> {
public:
    write_once_node( graph &g );
    write_once_node( const write_once_node &src );
    ~write_once_node();
 
    // receiver<T>
    typedef T input_type;
    typedef sender<input_type> predecessor_type;
    bool try_put( const input_type &v );
    bool register_predecessor( predecessor_type &p );
    bool remove_predecessor( predecessor_type &p );
 
    // sender<T>
    typedef T output_type;
    typedef receiver<output_type> successor_type;
    bool register_successor( successor_type &r );
    bool remove_successor( successor_type &r );
    bool try_get( output_type &v );
    bool try_reserve( output_type &v );
    bool try_release( );
    bool try_consume( );
 
    bool is_valid( );
    void clear( );
};
 
}
}
次の表は、このテンプレート・クラスのメンバーの詳細な情報を提供します。
メンバー 説明
write_once_node( graph &g )

無効な内部バッファーアイテムを含む graph g に属する write_once_node 型のオブジェクトを構築します。

write_once_node( const write_once_node &src )

無効な内部バッファーアイテムを含む write_once_node 型のオブジェクトを構築します。バッファーに格納される値とサクセサーのリストは src からコピーされません。

~write_once_node( )

write_once_node を破棄します。

bool try_put( const input_type &v )

内部の 1 アイテムのバッファーに有効な値が含まれていない場合、v を格納します。新しい値が設定された場合、すべてのサクセサーで try_put(v) を呼び出します。

戻り値: 構築後初めてまたは clear() への呼び出しの場合は true、その他の場合は false

bool register_predecessor( predecessor_type &p )

値を拒否しないため、プレデセッサーのリストを維持する必要はありません。

戻り値: false

bool remove_predecessor( predecessor_type &p )

値を拒否しないため、プレデセッサーのリストを維持する必要はありません。

戻り値: false

bool register_successor( successor_type &r )

サクセサーのセットに r を追加します。バッファーに有効なアイテム v が格納されている場合、r.try_put(v) を呼び出すタスクがスポーンされます。

戻り値: true

bool remove_successor( successor_type &r )

サクセサーのセットから r を削除します。

戻り値: true

bool try_get( output_type &v )

内部バッファーが有効な場合、値を v に代入します。

戻り値: v が代入された場合は truev が代入されなかった場合は false

bool try_reserve( output_type &v )

予約をサポートしません。

戻り値: false

bool try_release( )

予約をサポートしません。

戻り値: false

bool try_consume( )

予約をサポートしません。

戻り値: false

bool is_valid( )

戻り値: バッファーが有効な値を保持している場合は true。その他の場合は false

void clear( )

バッファーで保持されている値を無効にします。

関連情報