Virtual Base Classes By Nouf Aljaffan Edited by

Virtual Base Classes By: Nouf Aljaffan Edited by : Nouf Almunyif

• An element of ambiguity can be introduced into a C++ program when multiple base classes are inherited. • Consider the following incorrect program:

incorrect program: // This program contains an error and will not compile. #include <iostream> using namespace std; class base { public: int i; }; //derived 1 inherits base. class derived 1 : public base { public: int j; }; int main(){ derived 3 ob; ob. i = 10; //this is ambiguous; which i? ? ? ob. j = 20; ob. k = 30; // i ambiguous here, too ob. sum = ob. i + ob. j + ob. k; // also ambiguous, which i? cout << ob. i << « » cout << ob. j <<“ “ << ob. k <<“ “ ; cout << ob. sum; return 0; } //derived 2 inherits base. class derived 2 : public base { public: int k; }; /* derived 3 inherits both derived 1 and derived 2. This means that there are two copies of base in derived 3! */ class derived 3 : public derived 1, public derived 2 { public: int sum; }; Base Derived 1 Derived 3 Derived 2

As the comments in this program indicate • Both derivedl and derived 2 inherit base. • However, derived 3 inherits both derivedl and derived 2. • As a result, there are two copies of base present in an object of type derived 3, so that in an expression like �ob. i = 20; • which i is being referred to? The one in derivedl or the one in derived 2? • Since there are two copies of base present in object ob, there are two ob. is! As you can see, the statement is inherently ambiguous.

Solution • There are two ways to remedy the preceding program ▫ The first is to apply the scope resolution operator to i and manually select one i. �For example, the following version of the program will compile and run as expected

Resolve the incorrect program using 1 stapproach: class base { public: int i; }; class derived 1 : public base { public: int j; }; class derived 2 : public base { public: int k; }; // scope resolved ob. sum = ob. derived 1: : i + ob. j + ob. k; // scope resolved cout << ob. derived 1: : i << « » cout << ob. j <<“ “ << ob. k <<“ “ ; cout << ob. sum; return 0; } class derived 3 : public derived 1, public derived 2 { public: int sum; }; By applying the : : , the program manually selects derivedl's version of base. int main(){ derived 3 ob; However, this solution raises a deeper issue: What if only one copy of base is actually required? Is there some way to prevent two copies from being included in derived 3? ob. derived 1: : i = 10; //scope resolved, uses derived 1’s I ob. j = 20; ob. k = 30;

virtual base classes • The second is to declare the base class as virtual • The solution is achieved with virtual base classes. • virtual base classes ensures that only one copy of it will be present in any derived class

2’nd approach using virtual base classes // This program uses virtual base classes #include <iostream> using namespace std; class base { public: int i; }; int main(){ derived 3 ob; //derived 1 inherits base. class derived 1 : virtual public base { public: int j; }; // unambiguous ob. sum = ob. i + ob. j + ob. k; //derived 2 inherits base. class derived 2 : virtual public base { public: int k; }; /* derived 3 inherits both derived 1 and derived 2. This means that there is only one copy of base in derived 3! */ class derived 3 : public derived 1, public derived 2 { public: int sum; }; ob. i = 10; //scope resolved, uses derived 1’s I ob. j = 20; ob. k = 30; // unambiguous cout << ob. i << « » cout << ob. j <<“ “ << ob. k <<“ “ ; cout << ob. sum; return 0; } Now that both derivedl and derived 2 have inherited base as virtual, any multiple inheritance involving them will cause only one copy of base to be present. Therefore, in derived 3 there is only one copy of base, and ob. i = 10 is perfectly valid and unambiguous.

difference between a normal base class and a virtual • The only difference between a normal base class and a virtual one becomes evident when an object inherits the base class more than once. • If the base class has been declared as virtual, then only one instance of it will be present in the inheriting object. Otherwise, multiple copies will be found.
- Slides: 9