構造体とクラスのメンバーの反復
C では、構造体またはクラスのメンバーを反復して名前を取得することができます。そして価値観。これを実現するためのいくつかのアプローチを次に示します。
マクロの使用
REFLECTABLE マクロを使用して、イントロスペクションを可能にする構造体を定義できます。マクロは、構造体のメンバーを型と名前のペアのカンマ区切りリストとして定義します。例:
<code class="cpp">struct A { REFLECTABLE ( (int) a, (int) b, (int) c ) };</code>
構造体が定義されたら、ビジター関数を使用してそのメンバーを反復処理し、その名前と値を出力できます。
<code class="cpp">struct print_visitor { template<class fielddata> void operator()(FieldData f) { std::cout void print_fields(T & x) { visit_each(x, print_visitor()); } A x; print_fields(x);</class></code>
構造体の適応フュージョン シーケンスとして
もう 1 つのアプローチは、BOOST_FUSION_ADAPT_STRUCT マクロを使用して、構造体をフュージョン シーケンスとして適応させることです。このマクロは、構造体のメンバーを、対応する型と値を持つ要素のシーケンスとして定義します。例:
<code class="cpp">struct A { int a; int b; int c; }; BOOST_FUSION_ADAPT_STRUCT ( A, (int, a) (int, b) (int, c) )</code>
構造体が適応されたら、範囲ループを使用してメンバーを反復処理し、その名前と値を出力できます。
<code class="cpp">struct print_visitor { template<class index class c> void operator()(Index, C & c) { std::cout ::call() (c) void print_fields(C & c) { typedef boost::mpl::range_c<int boost::fusion::result_of::size>::type::value> range; boost::mpl::for_each<range>(boost::bind<void>(print_visitor(), boost::ref(c), _1)); }</void></range></int></class></code>
これらのアプローチの両方で、次のことが可能になります。構造体とクラスをイントロスペクトし、実行時にそのメンバーとその値へのアクセスを提供します。
以上がC で構造体とクラスのメンバーを反復処理して、実行時に名前と値にアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。