void *MyConfigDetail; if (x) { ((TType1 *) MyConfigDetail) = DetailCacheBeans; } else { ((TType2 *) MyConfigDetail) = DetailailCacheHam; } </rpr> But I am unable to access the "MyConfigDetail" elements as MyConfigDetail->Forks = 22; // for example Why not?
No, it is not.
Very great care should be used when "upgrading" a pointer.
It is almost always a bad sw design if a naked pointer has to be typecast like that. You may implement a generic list with void pointers, but then you normally create a new level of abstraction to get access functions that makes sure you insert pointers of type xx, and get back pointers of type xx, in which case the code that accesses the field Forks doesn't need any type cast.
There are many great ways to write lousy code that are hard to maintain. This is one of the top-ten ways - and definitely at the top half of the list...
That's like designing a mains-powered electrical device that requires you to poke bare wires into live sockets - it will "work", but it is highly dangerous and will cause a spectacular failure with the slightest slip...