迭代結構體和類別成員
在 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 << 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_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 << 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中文網其他相關文章!