使用 tr2::direct_bases 获取结果的第 n 个元素
Posted
技术标签:
【中文标题】使用 tr2::direct_bases 获取结果的第 n 个元素【英文标题】:using tr2::direct_bases get nth element of result 【发布时间】:2013-03-01 13:03:00 【问题描述】:struct T1 ;
struct T2: T1 ;
typedef tr2::direct_bases<T2>::type NEW_TYPE ;
应该将我的类似的东西返回到基本类型。我怎样才能得到第n个元素 这个 __reflection_typelist<...>。我为反射列表搜索类似 tuple_element 的东西。
【问题讨论】:
【参考方案1】:您可以使用这个简单的元函数将类型列表变成std::tuple
:
#include <tr2/type_traits>
#include <tuple>
template<typename T>
struct dbc_as_tuple ;
template<typename... Ts>
struct dbc_as_tuple<std::tr2::__reflection_typelist<Ts...>>
typedef std::tuple<Ts...> type;
;
此时,您可以像通常使用元组一样使用它。例如,您可以通过以下方式检索类型列表的元素:
struct A ;
struct B ;
struct C : A, B ;
int main()
using namespace std;
using direct_base_classes = dbc_as_tuple<tr2::direct_bases<C>::type>::type;
using first = tuple_element<0, direct_base_classes>::type;
using second = tuple_element<1, direct_base_classes>::type;
static_assert(is_same<first, A>::value, "Error!"); // Will not fire
static_assert(is_same<second, B>::value, "Error!"); // Will not fire
【讨论】:
感谢您的简化!我想知道为什么 tr2 不使用元组本身。会让事情变得更加严格。 1) 没有TR2,这东西在过渡2) 看gcc.gnu.org/ml/gcc-patches/2011-09/msg01789.html的解释【参考方案2】:自己写?
template <typename R, unsigned int N> struct get;
template <typename T, typename ...Args, unsigned int N>
struct get<std::tr2::__reflection_typelist<T, Args...>, N>
typedef typename get<std::tr2::__reflection_typelist<Args...>, N - 1>::type type;
;
template <typename T, typename ...Args>
struct get<std::tr2::__reflection_typelist<T, Args...>, 0>
typedef T type;
;
甚至使用first
/next
:
template <typename R, unsigned int N>
struct get
typedef typename get<typename R::next::type, N - 1>::type type;
;
template <typename R>
struct get<R, 0>
typedef typename R::first::type type;
;
在这一点上,我想说source code 是最好的文档。
【讨论】:
+1 表示first
/ next
示例。我会添加static_assert( !R::empty::value, "Cannot get element of empty typelist" )
或使用std::conditional<R::empty::value, void, blahblah>
以上是关于使用 tr2::direct_bases 获取结果的第 n 个元素的主要内容,如果未能解决你的问题,请参考以下文章
获取结果崩溃(使用 persistentContainer) - 核心数据目标 C