IN C++ To gain a better understanding of polymorphic and virtual functions start with the following simple example. Notice we have not defined a virtual function yet. // Part1.h. Note, this header file will have TWO classes declared. #include using namespace std; class Base { public: void testFunction (); }; class Derived : public Base { public: void testFunction (); }; // Part1.cpp. Note this implementation file will have TWO class defined. #include "Part1.h" void Base::testFunction () { cout << "Base class" << endl; } void Derived::testFunction () { cout << "Derived class" << endl; } // main.cpp #include "Part1.h" int main() { Base* ptr = new Base; ptr -> testFunction (); // prints "Base class" delete ptr; ptr = new Derived; ptr -> testFunction (); // prints "Base class" because the base class // function is not virtual delete ptr; return 0; } Now modify the code with the following (all other code should remain the same). class Base { public: virtual void testFunction (); }; Compile and run your program with this modification. You’ll notice the second testFunction() call generates the message “Derived class”. Welcome to polymorphism! No need to submit anything for this part of the lab, just make sure that virtual is clear to you. You will build two classes, Mammal and Dog. Dog will inherit from Mammal. Below is the Mammal class code. Once you have the Mammal class built, build a second class Dog that will inherit publicly from Mammal. The Dog class should also override the move() and speak() methods from Mammal. // Mammal.h class Mammal { public: Mammal(); ~Mammal(); virtual void move() const; virtual void speak() const; protected: int itsAge; }; // Mammal.cpp #include "Mammal.h" Mammal::Mammal():itsAge(1) { cout << "Mammal constructor..." << endl; } Mammal::~Mammal() { cout << "Mammal destructor..." << endl; } void Mammal::move() const { cout << "Mammal moves a step!" << endl; } void Mammal::speak() const { cout << "What does a mammal speak? Mammilian!" << endl; } Once you have completed class Mammal and Dog, build the following main program. #include "Mammal.h" #include "Dog.h" int main () { Mammal *pDog = new Dog; pDog->move(); pDog->speak(); //Dog *pDog2 = new Dog; //pDog2->move(); //pDog2->speak(); delete pDog; //delete pDog2; return 0; }  What does it output, and is that what you expected?  Remove the keyword virtual from the Mammal class and try it again. Now what happens? Next, put in another pointer to pDog2 in the main program, but this time make it a pointer to a Dog, not a Mammal and create a new Dog (as seen in code comments). Now what happens? What you should realize is that by making the method speak() virtual, we can have a bit different behavior through dynamic (runtime) binding. Develop additional classes for Cat, Horse, and GuineaPig overriding the move() and speak() methods. (If you didn’t know, guinea pigs go “wheep wheepLinks to an external site.”). Make sure to also define a constructor and destructor for each of these classes, and that when you run your program, you can also see that the correct constructors and destructors are being called. Recall that a derived class will always call the parents constructors and destructors, so if you see this behavior, that is okay. Just make sure you are also calling the derived class’ constructors and destructors.  Test with the modified main: int main () { Mammal* theArray[5]; Mammal* ptr; int choice; for (int i = 0; i < 5; i++) { cout << "(1)dog (2)cat (3)horse (4)guinea pig: "; cin >> choice; switch (choice) { case 1: ptr = new Dog; break; case 2: ptr = new Cat; break; case 3: ptr = new Horse; break; case 4: ptr = new GuineaPig; break; default: ptr = new Mammal; break; } theArray[i] = ptr; } // Iterate through array, and have each animal speak for (int i = 0; i < 5; i++) { theArray[i]->speak(); } // Always free dynamically allocated objects for (int i = 0; i < 5; i++) { delete theArray[i]; } return 0; } Sample run: (1)dog (2)cat (3)horse (4)guinea pig: 1 Mammal constructor... Dog constructor... (1)dog (2)cat (3)horse (4)guinea pig: 2 Mammal constructor... Cat constructor... (1)dog (2)cat (3)horse (4)guinea pig: 3 Mammal constructor... Horse constructor... (1)dog (2)cat (3)horse (4)guinea pig: 4 Mammal constructor... Guinea Pig constructor... (1)dog (2)cat (3)horse (4)guinea pig: 5 Mammal constructor... What does a dog say? Woof! What does a cat say? Meow! What does a horse say? Neigh! What does a Guinea Pig say? Wheep WHEEP! What does a mammal speak? Mammilian! Dog destructor... Mammal destructor... Cat destructor... Mammal destructor... Horse destructor... Mammal destructor... Guinea Pig destructor... Mammal destructor... Mammal destructor...

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

IN C++

  1. To gain a better understanding of polymorphic and virtual functions start with the following simple example. Notice we have not defined a virtual function yet.

// Part1.h. Note, this header file will have TWO classes declared.
#include <iostream>
using namespace std;
class Base
{
public:
void testFunction ();
};
class Derived : public Base
{
public:
void testFunction ();
};

// Part1.cpp. Note this implementation file will have TWO class defined.
#include "Part1.h"
void Base::testFunction ()
{
cout << "Base class" << endl;
}

void Derived::testFunction ()
{
cout << "Derived class" << endl;
}

// main.cpp
#include "Part1.h"
int main()
{
Base* ptr = new Base;
ptr -> testFunction (); // prints "Base class"
delete ptr;
ptr = new Derived;
ptr -> testFunction (); // prints "Base class" because the base class
// function is not virtual
delete ptr;

return 0;
}

Now modify the code with the following (all other code should remain the same).

class Base
{
public:
virtual void testFunction ();
};

Compile and run your program with this modification. You’ll notice the second testFunction() call generates the message “Derived class”. Welcome to polymorphism! No need to submit anything for this part of the lab, just make sure that virtual is clear to you.

  1. You will build two classes, Mammal and DogDog will inherit from Mammal. Below is the Mammal class code. Once you have the Mammal class built, build a second class Dog that will inherit publicly from Mammal. The Dog class should also override the move() and speak() methods from Mammal.

// Mammal.h
class Mammal
{
public:
Mammal();
~Mammal();
virtual void move() const;
virtual void speak() const;
protected:
int itsAge;
};

// Mammal.cpp
#include "Mammal.h"
Mammal::Mammal():itsAge(1)
{
cout << "Mammal constructor..." << endl;
}

Mammal::~Mammal()
{
cout << "Mammal destructor..." << endl;
}

void Mammal::move() const
{
cout << "Mammal moves a step!" << endl;
}

void Mammal::speak() const
{
cout << "What does a mammal speak? Mammilian!" << endl;
}

Once you have completed class Mammal and Dog, build the following main program.

#include "Mammal.h"
#include "Dog.h"
int main ()
{
Mammal *pDog = new Dog;

pDog->move();
pDog->speak();

//Dog *pDog2 = new Dog;

//pDog2->move();
//pDog2->speak();

delete pDog;
//delete pDog2;

return 0;
}

 What does it output, and is that what you expected?  Remove the keyword virtual from the Mammal class and try it again. Now what happens? Next, put in another pointer to pDog2 in the main program, but this time make it a pointer to a Dog, not a Mammal and create a new Dog (as seen in code comments). Now what happens? What you should realize is that by making the method speak() virtual, we can have a bit different behavior through dynamic (runtime) binding.

  1. Develop additional classes for CatHorse, and GuineaPig overriding the move() and speak() methods. (If you didn’t know, guinea pigs go “wheep wheepLinks to an external site.”). Make sure to also define a constructor and destructor for each of these classes, and that when you run your program, you can also see that the correct constructors and destructors are being called. Recall that a derived class will always call the parents constructors and destructors, so if you see this behavior, that is okay. Just make sure you are also calling the derived class’ constructors and destructors. 

    Test with the modified main:

    int main ()
    {
    Mammal* theArray[5];
    Mammal* ptr;
    int choice;
    for (int i = 0; i < 5; i++)
    {
    cout << "(1)dog (2)cat (3)horse (4)guinea pig: ";
    cin >> choice;
    switch (choice)
    {
    case 1: ptr = new Dog;
    break;
    case 2: ptr = new Cat;
    break;
    case 3: ptr = new Horse;
    break;
    case 4: ptr = new GuineaPig;
    break;
    default: ptr = new Mammal;
    break;
    }
    theArray[i] = ptr;
    }

    // Iterate through array, and have each animal speak
    for (int i = 0; i < 5; i++)
    {
    theArray[i]->speak();
    }

    // Always free dynamically allocated objects
    for (int i = 0; i < 5; i++)
    {
    delete theArray[i];
    }

    return 0;
    }

Sample run:

(1)dog (2)cat (3)horse (4)guinea pig: 1
Mammal constructor...
Dog constructor...
(1)dog (2)cat (3)horse (4)guinea pig: 2
Mammal constructor...
Cat constructor...
(1)dog (2)cat (3)horse (4)guinea pig: 3
Mammal constructor...
Horse constructor...
(1)dog (2)cat (3)horse (4)guinea pig: 4
Mammal constructor...
Guinea Pig constructor...
(1)dog (2)cat (3)horse (4)guinea pig: 5
Mammal constructor...
What does a dog say? Woof!
What does a cat say? Meow!
What does a horse say? Neigh!
What does a Guinea Pig say? Wheep WHEEP!
What does a mammal speak? Mammilian!
Dog destructor...
Mammal destructor...
Cat destructor...
Mammal destructor...
Horse destructor...
Mammal destructor...
Guinea Pig destructor...
Mammal destructor...
Mammal destructor...

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 4 steps with 5 images

Blurred answer
Knowledge Booster
ADT and Class
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education