구조체 및 클래스 멤버 반복
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!