开发者

Run time type information of base and derived classes

开发者 https://www.devze.com 2023-04-02 09:47 出处:网络
I\'m trying to extend the functionality of some classes that I do not have access to. Basically I\'m trying to create a toString/toXML method for logging purposes. I though开发者_StackOverflow中文版t

I'm trying to extend the functionality of some classes that I do not have access to.

Basically I'm trying to create a toString/toXML method for logging purposes. I though开发者_StackOverflow中文版t of creating a singleton (essentially a map) to which I can register the different functions and have them globally available in a fashion, so I can have something like string Singleton::toString(void* or abstractObject*) which would pick the correct method from the map depending on the type.

While I can get type information with typeid, I want to be able to implement it for a base class and then have all derived classes use that method, unless I there is a 'closer' / more appropriate method.

Would that be possible, or should I change to a different method (can templates do that)? I can not access the classes in question unfortunately, as most of them are from 3rd party libraries.


I have found that the following is a very simple way for me to keep track of the types of base and derived structures or classes that I define.

_kind does not have to be a string. In fact, it should probably be an enum. However, since I was designing a rather high level program when I came up with this, strings were fast enough for me.

struct base
{
protected:
    string _kind;
public:
    base()
    {
        _kind = "base";
    }

    ~base()
    {
    }

    string kind()
    {
        return _kind;
    }
}
struct derived : base
{
    derived()
    {
        _kind = "derived";
    }
    ~derived()
    {
    }
}

For built-in structures, perhaps overload the toString and toXML methods and let the compiler decide?

string toString(structure1 A)
{
...
}
string toString(structure2 A)
{
...
}

This might get a little confusing for derived structures, however I think the compiler will choose the leaf structure as the type instead of the base.

For example, if you have types A : B : C : D, and function f is defined for C and A. If you input a variable of type B, then it should be auto typecasted to A. If you input a variable of type C, then it will use the function for type C. If you input a variable of type D, then it should be auto typecasted to type C and then the C function should be called.

You might also try templates which essentially does the same thing.

template <class t>
string toString(t A)
{
...
}

Cheers, Ned

0

精彩评论

暂无评论...
验证码 换一张
取 消