Can't downcast because class is not polymorphic?

C++InheritancePolymorphismVtable

C++ Problem Overview


Is it possible to have inheritance with no virtual methods? The compiler is saying that the following code is not polymorphic.

Example:

class A {
public:
    int a;
    int getA(){return a;};
}


class B : public A {
public:
    int b;
    int getB(){return b;};
}

In another class we are trying to downcast from an A object to a B object:

 A *a = ...;
 B *b = dynamic_cast<B*>(a)

but this gives the following compile-time error:

 cannot dynamic_cast ... (source type is not polymorphic)

C++ Solutions


Solution 1 - C++

Syntax errors non-withstanding, you cannot dynamic_cast a non-polymorphic type. static_cast is the cast you would use in this case, if you know that it is in fact an object of the target type.

The reason why: static_cast basically has the compiler perform a check at compile time "Could the input be cast to the output?" This is can be used for cases where you are casting up or down an inheritance hierarchy of pointers (or references). But the check is only at compile time, and the compiler assumes you know what you are doing.

dynamic_cast can only be used in the case of a pointer or reference cast, and in addition to the compile time check, it does an additional run time check that the cast is legal. It requires that the class in question have at least 1 virtual method, which allows the compiler (if it supports RTTI) to perform this additional check. However, if the type in question does not have any virtual methods, then it cannot be used.

The simplest case, and probably worthwhile if you're passing pointers around like this, is to consider making the base class's destructor virtual. In addition to allowing you to use dynamic cast, it also allows the proper destructors to be called when a base class pointer is deleted.

Solution 2 - C++

You need at least one virtual method in a class for run-time type information (RTTI) to successfully apply dynamic_cast operator.

Solution 3 - C++

just make A destructor virtual (always do for any class just for safety).

Solution 4 - C++

yes, dynamic_cast for non-polymorphic types are not allowed. The base class shall have at least one virtual method. Only then that class can be called as polymorphic.

This article explains a similar example: http://www.cplusplus.com/doc/tutorial/typecasting/

Solution 5 - C++

A a;
B *b = dynamic_cast<B*>(a)

Here a is an object and b is a pointer.

Actually, upcasting and downcasting are both allowed in C++. But when using downcasting, 2 things should be pay attention to:

  1. The superclass should has at least one virtual method.
  2. Since superclass is "smaller" than subclass, one should use memory object carefully.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionwfbarksdaleView Question on Stackoverflow
Solution 1 - C++Dave SView Answer on Stackoverflow
Solution 2 - C++tenorsaxView Answer on Stackoverflow
Solution 3 - C++user993954View Answer on Stackoverflow
Solution 4 - C++Murali KrishnaView Answer on Stackoverflow
Solution 5 - C++tygerView Answer on Stackoverflow