将RTTI用于普通旧结构(gcc)

时间:2016-03-30 23:49:02

标签: c++ rtti

我需要"附上"到外部(不可修改的)结构某种RTTI信息。

正如我从gcc实现中看到的那样,带有虚方法的struct另外还有一个指向与type_info相关的结构的指针。

所以我需要通过使用具有两个部分的双指针来操作这些外部结构:数据指针和"类型"指针。这个双指针具有"正常"的所有信息。 RTTI结构。你知道吗" legal"或hacky方式来做到这一点

1 个答案:

答案 0 :(得分:2)

为此创建一个智能指针类:

#include <typeindex>
#include <type_traits>

// minimal implementation
template<typename T>
class RTTIPointer
{
    T* ptr_;
    std::type_index type_;
public:
    template<typename U, typename std::enable_if<std::is_convertible<U*, T*>::value>::type* = nullptr>
    RTTIPointer(U* p) :
        ptr_(p),
        type_(typeid(*p))
    {

    }

    // typename std::add_lvalue_reference<T>::type instead of T&
    // to support void pointers
    typename std::add_lvalue_reference<T>::type operator*() const
    {
        return *ptr_;
    }

    T* operator->() const
    {
        return ptr_;
    }

    T* get() const
    {
        return ptr_;
    }

    std::type_index type() const
    {
        return type_;
    }
};

struct Base { int a; };
struct Derived : Base { int b; };

#include <iostream>

int main()
{
    Derived b;
    b.a = 2;
    b.b = 3;
    RTTIPointer<Base> r(&b);
    std::cout << r->a << "\n" << r.type().name() << "\n";
    RTTIPointer<void> q(&b);
    std::cout << r.type().name() << "\n";
}

输出:

2
7Derived
7Derived