Maison >développement back-end >C++ >Comment fonctionne `dynamic_cast` de C et peut-il être simulé en C ?
Déchiffrer Dynamic_cast en C
Comprendre le mot-clé Dynamic_cast en C peut être déroutant. Voici une analogie simplifiée pour vous aider à comprendre son essence.
static_cast et Dynamic_cast pour les pointeurs
Imaginez static_cast comme un bibliothécaire méticuleux qui vérifie strictement que deux livres (types de pointeurs) appartiennent à la même allée (hiérarchie des classes). Cependant, s'ils ne le font pas, cela suggère poliment que la demande n'est pas valide et qu'aucun cast ne peut être effectué.
D'un autre côté, Dynamic_cast est comme un détective ingénieux qui enquête sur le problème au moment de l'exécution. Il examine le contenu réel du livre (objet) pour déterminer s’il appartient à l’allée (classe) souhaitée. Si oui, il renvoie une référence à ce livre ; sinon, il conclut que la requête n'est pas valide et renvoie un pointeur nul.
Équivalents C
Il n'y a pas d'équivalent direct à Dynamic_cast en C. Cependant, vous pouvez simuler sa fonctionnalité utilisant une combinaison de fonctions arithmétiques de pointeur et virtuelles. Voici un exemple :
#define DYNAMIC_CAST(DerivedType, BaseType, MemberFunc, Args) \ ((DerivedType*) \ (((BaseType*)this)->MemberFunc(Args) + sizeof(BaseType) - sizeof(DerivedType)))
Cette macro prend un type dérivé, un type de base, une fonction membre qui renvoie un pointeur vers la table virtuelle et tous les arguments requis. Il convertit dynamiquement un pointeur de base en un pointeur dérivé en calculant le décalage de l'objet dans la table virtuelle du type dérivé et en ajustant le pointeur en conséquence.
Un exemple concret
struct Base { virtual const char* Identify() { return "Base"; } }; struct Derived : Base { virtual const char* Identify() { return "Derived"; } }; int main() { Base* base = new Derived(); Derived* derived = DYNAMIC_CAST(Derived, Base, Identify, NULL); printf("Object type: %s\n", derived->Identify()); return 0; }
Sortie :
Object type: Derived
Remarque : Cette simulation est quelque peu limitée car elle ne gère pas plusieurs niveaux d'héritage ou de classes abstraites. Cependant, il fournit une approximation proche des fonctionnalités de Dynamic_cast, vous permettant de mieux apprécier sa puissance en C .
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!