在编译时查找基类
Finding base class at compile time
标题几乎说明了一切: C++有没有办法在编译时获取类的基类型? 即是否可以将类交给模板,并让模板使用其他模板,它将给定类的基础交给它?
我的问题不是我是否可以自己实现这样的功能,毫无疑问我可以(使用特征等)。我的问题是是否有一些(晦涩的)内置功能可用于此目的。
gcc
支持这一点。看
- 克
- 雷克的回答
- TR2/type_traits
- Andy Prowl 的代码示例
- N2965
- N2965 - std::bases 和 std::d irect_bases 的状态如何?
- 如何在编译时查询类的所有基类?
N2965 提供了一个示例。
这个简单的示例说明了这些类型特征的结果。在 假设我们有以下类层次结构:
class E {}; class D {}; class C : virtual public D, private E {}; class B : virtual public D, public E {}; class A : public B, public C {};
因此,
bases<A>::type is tuple<D, B, E, C, E>
同样,
direct_bases<A>::type is tuple<B, C>
Andy Prowl 的代码示例如下:
#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
}
相关文章:
- std::具有相同基类的类的变体
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 基类中的函数名称解析
- C++初始化基类
- 如何通过派生类函数更改基类中的向量
- 如何定义一个纯抽象基类
- 如何使用基类指针引用派生类成员
- 继承:构造函数,初始化C++11中基类的类C数组成员
- 使用基类指针创建对象时,缺少派生类析构函数
- 如何引用基类的派生类?
- 如果基类包含双指针成员,则派生类的构造函数
- 限定的依赖名称查找,其中包含基类的注入类名
- 使用不包括基类的模板从C++中的列表中查找特定类型
- 如何查找多态基类向量中包含的对象的类型?
- 在编译时查找基类
- 在继承构造函数后查找基类名称
- 使用基类指针查找派生类对象的大小
- 使用带boost::shared_ptr的基类在映射中查找
- 限定基类的名称查找