Unit 4
Need of Inheritance
To increase the reusability of the code and to make further usable for another classes.
So ,we use the concept of inheritance To increase the reusability of the code and to
make further usable for another classes.
“Inheritance is the mechanism which provides the power of reusability and
extendibility.”
“Inheritance is the process by which one object can acquire the properties of
another object.”
“Inheritance is the process by which new classes called derived classes are
created from existing classes called base classes.”
Allows the creation of hierarchical classifications.
Explain different types of Inheritance with example.
Inheritance is a process of creating new Class from the existing Class. The
derived class/newly created class inherits all the properties from the base class.
Existing Class (Source Class) is known as Parent Class or Base Class.
About Base Class:
•“Base class is a class which defines those qualities common to all objects to be
derived from the base.”
•The base class represents the most general description.
•A class that is inherited is referred to as a base class.
Newly Created Class is known as Child Class or Derived Class.
About Derived Class:
•“The classes derived from the base class are usually referred to as derived
classes.”
• “A derived class includes all features of the generic base class and then adds
qualities specific to the derived class.”
•The class that does the inheriting is called the derived class.
Syntax of Inheritance
class parent_class
{
//Body of parent class
};
class child_class : access_modifier parent_class
{
//Body of child class
}
Access modes or visibility modes of inheritance:
We have seen two access modes in C++ classes: public and private.
Private mode is not accessible.
Public members are directly accessible by users of the class.
Protected members are directly accessible by derived classes but not by other
users.
Private members are NOT directly accessible by users of the class, not even by
inheritors.
Types of Inheritance in C++
There are five types in Inheritance.
1) Single inheritance
2) Multilevel inheritance
3) Multiple inheritance
4) Hierarchical inheritance
5) Hybrid inheritance
1. Single Inheritance
In Single Inheritance, one child class is derived from one base class.
Example Program for single inheritance:
#include<iostream.h>
#include<conio.h>
class Base_class
{
public:
Base_class()
{
cout<<"Content of Base class / Parent Class"<<endl;
}
};
class Dereived_class: public Base_class
{
public:
Dereived_class()
{
cout<<" Content of Derived class / Child Class";
}
};
void main()
{
//Creating object of class derived class
Dereived_class obj;
getch();
}
Output for Single Inheritance
Multilevel Inheritance
In multilevel Inheritance, one child class is derived from the another child class.
ie. Child Class C derived from another Child Class B.
Image : Multilevel Inheritance
From the Above image, class B is derived from the base class A and then class C is
derived from the derived class B.
Example Program for Multilevel Inheritance
#include<iostream.h>
#include<conio.h>
class A
{
public:
void display1()
{
cout<<"Base class A content";
cout<<endl;
}
};
class B:public A
{
public:
void display2()
{
cout<<"Derived class B content";
cout<<endl;
}
};
class C:public B
{
};
void main()
{
clrscr();
C obj;
obj.display1();
obj.display2();
getch();
}
Output for Multilevel Inheritance:
Example Program for Mutilevel Inheritance
Write a Program to Display Student Result using Mutilevel Inheritance
#include<iostream.h>
#include<conio.h>
#include<stdio.h>
class student_info
{
public:
char name[100], regno [20];
void get_info()
{
cout<< "Enter the Student Name: ";
gets(name);
cout<< "Enter the Student Register No: "; cin>>regno;
}
};
class department_info:public student_info
{
public:
char dept[20];
void get_department()
{
cout<< "Enter the Department Name: ";
gets(dept);
//cout<<endl;
}
};
class mark : public department_info
{
public:
int tamil,english,maths,commerce,economics,total;
void get_mark()
{
cout<< "Enter the Tamil Mark: ";
cin>>tamil;
cout<< "Enter the English Mark: ";
cin>>english;
cout<< "Enter the Maths Mark: ";
cin>>maths;
cout<< "Enter the Commerce Mark: ";
cin>>commerce;
cout<< "Enter the Economics Mark: ";
cin>>economics;
total=(tamil+english+maths+commerce+economics);
}
void display()
{
cout<<"--------------------------------------------"<<endl;
cout<<"Student Name is :";
puts(name);
cout<<"Student Register Number:"<<regno<<endl;
cout<<"Department Name:";
puts(dept);
if((tamil>=35) && (english>=35) && (maths>=35) && (commerce>=35) &&
(economics>=35))
{
cout<<"Your are Pass....Congrats"<<endl;
}
else
{
cout<<"Your are Fail"<<endl;
}
cout<<"Total Mark is:"<<total;
}
};
void main()
{
clrscr();
mark d;
d.get_info();
d.get_department();
d.get_mark();
d.display();
getch();
}
Output of Mutileve Inheritance Program:
3) Multiple Inheritance
In Multiple Inheritance, a child class is derives from multiple base classes.
According to below figure, Class A & B are Base Class (Parent) to the Derived Class C.
Figure : Multiple Inheritance
Example Program for Multiple Inheritance
#include<iostream.h>
#include<conio.h>
class A //Base Class A
{
public:
A ()
{
cout << "Base Class A" << endl;
}
};
class B //Base Class B
{
public:
B ()
{
cout << "Base Class B" << endl;
}
};
class Child: public A, public B //Derived Class C from Base Class A & B
{
};
void main()
{ clrscr();
Child c;
getch();
}
Output for Multiple Inheritance
Example Program for Multiple Inheritance
Write a Program to Display Student Result using Multiple Inheritance.
#include<iostream.h>
#include<conio.h>
#include<stdio.h>
class student_info
{
public:
char name[100], regno [20],dept[20];
void get_info()
{
cout<< "Enter the Student Name: ";
gets(name);
cout<< "Enter the Student Register No: "; cin>>regno;
cout<< "Enter the Department Name: ";
gets(dept);
}
};
class mark
{
public:
int tamil,english,maths,commerce,economics,total;
void get_mark()
{
cout<< "Enter the Tamil Mark: ";
cin>>tamil;
cout<< "Enter the English Mark: ";
cin>>english;
cout<< "Enter the Maths Mark: ";
cin>>maths;
cout<< "Enter the Commerce Mark: ";
cin>>commerce;
cout<< "Enter the Economics Mark: ";
cin>>economics;
total=(tamil+english+maths+commerce+economics);
}
};
class result: public student_info, public mark
{
public:
void display()
{
cout<<"------------------------------------------";
cout<<endl;
cout<<"Student Name is :";
puts(name);
cout<<"Student Register Number:"<<regno<<endl;
cout<<"Department Name:";
puts(dept);
cout<<"Total Mark is:"<<total;
cout<<endl;
}
void results()
{
if((tamil>=35) && (english>=35) && (maths>=35) && (commerce>=35) &&
(economics>=35))
{
cout<<"Your are Pass....Congrats";
}
else
{
cout<<"Your are Fail";
}
cout<<endl;
cout<<"------------------------------------------";
}
};
void main()
{
clrscr();
result d;
d.get_info();
d.get_mark();
d.display();
d.results();
getch();
}
Output of Multiple Inheritance Program:
4.Hierarchical Inheritance
In Hierarchical inheritance, more than one child class are created from one
base class.
According to below figure, Child Class B,C,D are Derived from the Parent Class
A.
Figure : Hierarchical inheritance
Example Program for Hierarchical Inheirtance
#include<iostream.h>
#include<conio.h>
class A
{
public:
A()
{
cout<<"Constructor of A class"<<endl;
}
};
class B: public A // Class B Derived from Parent Class A
{
public:
B()
{
cout<<"Constructor of B class"<<endl;
}
};
class C: public A // Class C Derived from Parent Class A
{
public:
C()
{
cout<<"Constructor of C class"<<endl;
}
};
void main()
{
//Creating object of class C
clrscr();
B obj1;
C obj2;
getch();
}
Output for Hierarchical Inheritance:
5) Hybrid Inheritance
Hybrid inheritance is a combination of more than one type of inheritance.
For example, A child and parent class relationship that follows multiple and
hierarchical inheritance both can be called hybrid inheritance.
Discuss about Pointer Concepts in detail.
A Pointer is a variable in C++.
It stores the memory address of another variable. Pointers provide a way to manipulate
memory dynamically.
Usage of pointer
1) Dynamic memory allocation
we can dynamically allocate memory using malloc() and calloc() functions where pointer is used.
2) Arrays, Functions and Structures
Pointers are widely used in arrays, functions and structures. It reduces the code and improves the
performance.
Declaring a pointer
The pointer in C++ language can be declared using ∗ (asterisk symbol).
int ∗ a; //pointer to int
char ∗ c; //pointer to char
#include <iostream.h>
#include <conio.h>
void main()
{
int number=30;
int ∗ p;
p=&number; //stores the address of number variable
cout<<"Address of number variable is:"<<&number<<endl;
cout<<"Address of p variable is:"<<p<<endl;
cout<<"Value of p variable is:"<<*p<<endl;
getch();
}
Output
Address of number variable is:0x7ffccc8724c4
Address of p variable is:0x7ffccc8724c4
Value of p variable is:30
Types of Pointers:
1. C++ Void Pointer
2. Function Pointer in C++
1. C++ Void Pointer
A void pointer is a general-purpose pointer that can hold the address of any data type, but it is
not associated with any data type.
void *ptr; // void pointer declaration
int a=9; // integer variable initialization
ptr=&a; // storing the address of 'a' variable in a void pointer variable.
2. Function Pointer in C++
The function pointer is a pointer used to point functions. It is basically used to store the address
of a function
int (*funcptr)(int,int); // function pointer declaration
funcptr=add; // funcptr is pointing to the add function
Example Program for Function Pointer:
#include <iostream.h>
#include <conio.h>
int add(int a , int b)
{
return a+b;
}
void main()
{
int (*funcptr)(int,int); // function pointer declaration
funcptr=add; // funcptr is pointing to the add function
int sum=funcptr(5,5);
cout<< "value of sum is :" <<sum;
getch();
}
Output:
value of sum is : 10
Heap Memory
In C++, heap memory, also known as dynamic memory, is a region of memory used for dynamic
allocation. It's managed manually by the programmer using operators like new and delete.
new Operator and delete Operator :
new operator is a memory allocation operator
new operator is used to dynamically allocate memory on the heap for an object or an
array of objects.
delete operator is used to deallocate the memory.
Syntax of new operator
Pointer_name=new datatype;
Example:
int *ptr=new int;
Syntax of delete operator
delete Pointer_name;
delete ptr;
Example Program for new and delete Operators in C++
#include <iostream.h>
#include <conio.h>
void main()
{
int *ptr; // integer pointer variable declaration
ptr=new int; // allocating memory to the pointer variable ptr.
cout << "Enter the number : " <<endl;
cin >>*ptr;
cout << "Entered number is " <<*ptr;
delete ptr; // deallocate the memory
getch();
}
Output:
Discuss about Polymorphism in detail.
The term "Polymorphism" is a greek word
It is the combination of "Poly" + "Morphs" which means many forms.
Let's consider a real-life example of polymorphism. A lady behaves like a teacher in a
classroom, mother or daughter in a home and customer in a market. Here, a single person
is behaving differently according to the situations.
Types of Polymorphism:
In C++ polymorphism is mainly divided into two types:
1. Compile time Polymorphism
2. Runtime Polymorphism
Compile Time Polymorphism:
This type of polymorphism is achieved by Function Overloading or Operator Overloading.
1).Function Overloading.
Function overloading is a C++ programming feature.
It allows us to create more than one function with same name but different parameters
list.
Another name of Function overloading is compile-Time Polymorphism.
Example: (Same function name and differ in parameters list)
int sum(int num1,int num2); // Two Parameters
int sum(int num1,int num2, int num3); // Three Parameters
Example Program for Function Overloading:
#include<iostream.h>
#include<conio.h>
class Addition
{
public:
int sum(int num1,int num2)
{
cout<<"Function with Same Name & Two Parameters";
return num1+num2;
}
int sum(int num1,int num2, int num3)
{
cout<<"Function with Same Name & Three Parameters";
return num1+num2+num3;
}
};
void main()
{
clrscr();
Addition obj;
cout<<obj.sum(20, 15)<<endl;
cout<<obj.sum(10, 20, 10);
}
Output for Function Overloading:
2). Operator Overloading
I. The process of making an operator to perform different Jobs/functions in different
situation is known as operator overloading.
II. Operator Overloading is a Run Time Polymorphism.
Eg: Multiplication Operator (X)
If X Operator placed between two numbers, then it will perform of Multiplication
operation (c = 2 X 5)
Also, we can use Multiplication Operator (X) as a function name using Operator
Overloading.
How to Overload the Operator:
To Overload a Operator, a Operator Function is defined inside a class as below:
Syntax for Operator Overloading:
Return Type Operator Operator_Symbol(Parameter list)
{
Function Body
}
Example for Operator Over Loading:
void operator *()
{
//Function Body
}
Syntax to Call Operator Overloaded Function from Main:
OpeatorSymbol Objectname; (Without Space)
*Area; // * is the Operator and Area is the Object Name (See below example Program)
Example Program for Operator Overloading:
#include<iostream.h>
#include<conio.h>
class Circle
{
public:
float radius, area;
void get_radius()
{
cout<<"Enter the Radius of the Circle :";
cin>>radius;
}
void operator *() //Syntax for Operator Overloading
{
area=3.14 * (radius*radius);
cout<<"Area of the Circle is:"<<area;
}
};
void main()
{
clrscr();
Circle Area;
Area.get_radius();
*Area; // * is the Operator and Area is the Object Name of Class Rectangle
getch();
}
Output:
2. Run-time Polymorphism
Run-time Polymorphism is achieved through function overriding using virtual functions.
Function Overriding and Virtual Function:
Function Overriding
Function overriding in C++ is a concept by which you can define a function of the same name in
both the base class and derived class with a different function definition. It overrides / redefines a
function of the base class that inside the derived class during run time.
Virtual Function:
A Virtual Function is a member function which is declared within a base class and is re-
defined(Overriden) by a derived class during run time.
When you refer to a Derived Class object using a pointer or a reference to the base class,
you can call a virtual function for that object and execute the derived class’s version of
the function.
They are mainly used to achieve Runtime polymorphism. Functions are declared with a virtual
keyword in base class.
Rules for Virtual Functions
1. Virtual functions cannot be a friend function of another class.
2. Virtual functions should be accessed using pointer or reference of base class type to achieve
run time polymorphism.
3. The prototype of virtual functions should be same in base as well as derived class.
4. They are always defined in base class and overridden in derived class.
class base
{
public:
virtual void print ()
{ cout<< "print base class" <<endl; }
void show ()
{ cout<< "show base class" <<endl; }
};
class derived:public base
{
public:
void print ()
{ cout<< "print derived class" <<endl; }
void show ()
{ cout<< "show derived class" <<endl; }
};
int main()
{
base *bptr;
derived d;
bptr = &d;
//virtual function, binded at run time
bptr->print();
// Non-virtual function, binded at compile time
bptr->show();
}
C++
Copy
Output :
print derived class
show base class
Discuss about Managing Console I/O Operations in C++.
Every program takes input data and displays the output data through
output devices.
Cin ( >>) and COUT (<<) are used to get and display the data in C++.
C++ uses the concept of stream and stream classes to implement its I/O
operations with the console and disk files.
A stream is a sequence of Bytes. In C++, streams handle all I/O operations.
Input Stream: Input stream gets input data from the input device and send the
input data to corresponding program for processing.
Output Stream: Output Stream gets the output data from program and send it
to the display screen , i.e. from main memory to device( display screen).
Figure – Data Streams
The C++ I/O streams contains hierarchy of classes that are used to define
various streams to deal with both the console and disk files.
These classes are called as stream classes.
These classes are declared in the header file iostream.
The class ios is the base class for istream(input stream)and
ostream(output stream).
The class ios provides the basic support for formatted and unformatted I/O
operations.
The class istream used for formatted and unformatted input functions.
The class ostream used for formatted and unformatted output functions .
The class iostream provides the facility for handling both input and output
streams.
Three classes,namely, istream_withassign, ostream_withassign and
iostream_withassign add assignment operators to these classes.
Figure – C++ Stream Classes
There are two types of I/O Operations as follows:
1.Unformatted Console I/O Operations
2.Formatted Console I/O Operations
1.Unformatted Console I/O Operations
Unformatted I/O functions are used for direct input/output operations:
i. Console Output (cout)
cout is used for displaying output on the screen.
It is an instance of the ostream class.
The insertion operator (<<) is used to send data to the console.
ii. Console Input (cin)
cin is used for taking input from the user.
It is an instance of the istream class.
The extraction operator (>>) is used to read input.
iii. get(), getline(), put()
get(), put() – Character input/output
getline() – Read an entire line
Example:
cin.get(c);
cout.put(c);
char name[20];
cin.getline(name,20);
cout.write(name,9);
2. Formatted Console I/O
C++ provides several functions to format the output, such as:
setw() – Set minimum field width
setprecision() – Set decimal precision
setfill() – Fill characters
Example Program:
#include<iostream.h>
#include<conio.h>
#include <iomanip.h>
void main()
{
clrscr();
double pi = 3.1415926535;
cout << "Default: " << pi << endl;
cout << "Precision(3): " <<setprecision(3)<< pi << endl;
cout << "Width(10): " << setw(10)<<pi<<endl;
cout << "Width(15): " <<setfill('*')<<setw(15)<<setprecision(4)<<pi;
getch();
Output: