ホームページ  >  記事  >  バックエンド開発  >  C で構造体とクラスのメンバーを反復処理するにはどうすればよいですか?

C で構造体とクラスのメンバーを反復処理するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-30 06:48:02331ブラウズ

How can I iterate through the members of structs and classes in C  ?

構造体とクラスのメンバーの反復探索

C は、構造体とクラスのメンバーを反復するためのさまざまなメソッドを提供し、内部要素の詳細な探索を可能にします。

構造化検索用の REFLECTABLE マクロ

テクニックの 1 つは、REFLECTABLE マクロの利用です。以下に示すように、構造体定義に 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 << f.name() << "=" << f.get() << std::endl;
    }
};

template<class T>
void print_fields(T & x)
{
    visit_each(x, print_visitor());
}

A x;
print_fields(x);</code>

構造体を融合シーケンスとして適応させる

あるいは、Boost.Fusion を使用して構造体を融合シーケンスとして適応させることもできます。以下に例を示します:

<code class="cpp">struct A
{
    int a;
    int b;
    int c;
};

BOOST_FUSION_ADAPT_STRUCT
(
    A,
    (int, a)
    (int, b)
    (int, c)
)</code>

REFLECTABLE メソッドと同様に、フィールドを出力できます:

<code class="cpp">struct print_visitor
{
    template<class Index, class C>
    void operator()(Index, C & c)
    {
        std::cout << boost::fusion::extension::struct_member_name<C, Index::value>::call() 
                  << "=" 
                  << boost:::fusion::at<Index>(c) 
                  << std::endl;
    }
};

template<class C>
void print_fields(C & c)
{
    typedef boost::mpl::range_c<int,0, boost::fusion::result_of::size<C>::type::value> range;
    boost::mpl::for_each<range>(boost::bind<void>(print_visitor(), boost::ref(c), _1));
}</code>

以上がC で構造体とクラスのメンバーを反復処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。