Name: Abdul Gani Roll No: 201DDE1184 Course: MCA Year/Sem: 2 / 3 Paper Code: MCA 305 Paper Name: (Programming in C++)
Name: Abdul Gani Roll No: 201DDE1184 Course: MCA Year/Sem: 2 / 3 Paper Code: MCA 305 Paper Name: (Programming in C++)
Name: Abdul Gani Roll No: 201DDE1184 Course: MCA Year/Sem: 2 / 3 Paper Code: MCA 305 Paper Name: (Programming in C++)
ROLL NO : 201DDE1184
COURSE : MCA
YEAR/SEM : 2nd / 3rd
PAPER CODE : MCA 305
PAPER NAME : (PROGRAMMING IN C++)
Q-1. What is Reusability?
Myths of reuse:
Nontechnical obstacles:
The author of Widget must have suspected that a reusable version of Widget would be
useful.
The author of Widget must have expected to be rewarded for writing Widget reusably
and making it available.
Someone must maintain Widget.
The eventual user of Widget must suspect that Widget exists and must be able to find
it.
The eventual user of Widget must be able to obtain Widget.
There must be no legal obstacles to reuse of Widget.
The user of Widget must be rewarded for reusing Widget.
Technical obstacles:
Reusable code must work in many contexts.
We almost never know all the contexts.
User requirements often conflict.
We cannot provide everything everyone wants.
The contexts change.
Header Files : The files that tell the compiler how to call some functionality (without
knowing how the functionality actually works) are called header files. They contain the
function prototypes. They also contain Data types and constants used with the libraries. We
use #include to use these header files in programs. These files end with .h extension.
Library : Library is the place where the actual functionality is implemented i.e. they contain
function body. Libraries have mainly two categories :
Static
Shared or Dynamic
Static : Static libraries contains object code linked with an end user application and then they
become the part of the executable. These libraries are specifically used at compile time which
means the library should be present in correct location when user wants to compile his/her C
or C++ program. In windows they end with .lib extension and with .a for MacOS.
Shared or Dynamic : These libraries are only required at run-time i.e, user can compile
his/her code without using these libraries. In short these libraries are linked against at compile
time to resolve undefined references and then its distributed to the application so that
application can load it at run time. For example, when we open our game folders we can find
many .dll(dynamic link libraries) files. As these libraries can be shared by multiple programs,
they are also called as shared libraries.These files end with .dll or .lib extensions. In windows
they end with .dll extension.
Argument
An argument is referred to the values that are passed within a function when the function is
called. These values are generally the source of the function that require the arguments during
the process of execution. These values are assigned to the variables in the definition of the
function that is called. The type of the values passed in the function is the same as that of the
variables defined in the function definition. These are also called Actual arguments or
Actual Parameters.
Example: Suppose a sum() function is needed to be called with two numbers to add. These
two numbers are referred to as the arguments and are passed to the sum() when it called from
somewhere else.
Parameters
The parameter is referred to as the variables that are defined during a function declaration or
definition. These variables are used to receive the arguments that are passed during a function
call. These parameters within the function prototype are used during the execution of the
function for which it is defined. These are also called Formal arguments or Formal
Parameters.
Example: Suppose a Mult() function is needed to be defined to multiply two numbers. These
two numbers are referred to as the parameters and are defined while defining the function
Mult().
Argument Parameters
When a function is called, the values that The values which are defined at the time of the
are passed during the call are called as function prototype or definition of the function
arguments. are called as parameters.
These are used in function call statement to These are used in function header of the called
send value from the calling function to the function to receive the value from the
receiving function. arguments.
During the time of call each argument is Parameters are local variables which are
always assigned to the parameter in the assigned value of the arguments when the
function definition. function is called.
They are also called Actual Parameters They are also called Formal Parameters
In this program, we have a pointer ptr that points to the 0th element of the array. Similarly, we
can also declare a pointer that can point to whole array instead of only one element of the
array. This pointer is useful when talking about multidimensional arrays.
Syntax:
data_type (*var_name)[size_of_array];
Here ptr is pointer that can point to an array of 10 integers. Since subscript have higher
precedence than indirection, it is necessary to enclose the indirection operator and pointer
name inside parentheses. Here the type of ptr is ‘pointer to an array of 10 integers’.
Note : The pointer that points to the 0th element of array and the pointer that points to the
whole array are totally different.
Pointers and two dimensional Arrays: In a two dimensional array, we can access each
element by using two subscripts, where first subscript represents the row number and second
subscript represents the column number. The elements of 2-D array can be accessed with the
help of pointer notation also. Suppose arr is a 2-D array, we can access any element arr[i][j]
of the array using the pointer expression *(*(arr + i) + j). Now we’ll see how this expression
can be derived.
Let us take a two dimensional array arr[3][4]:
We can consider a three dimensional array to be an array of 2-D array i.e each element of a 3-
D array is considered to be a 2-D array. The 3-D array arr can be considered as an array
consisting of two elements where each element is a 2-D array. The name of the array arr is a
pointer to the 0th 2-D array.
In C++, inheritance is a process in which one object acquires all the properties and behaviors
of its parent object automatically. In such way, you can reuse, extend or modify the attributes
and behaviors which are defined in other class.
In C++, the class which inherits the members of another class is called derived class and the
class whose members are inherited is called base class. The derived class is the specialized
class for the base class.
Code reusability: Now you can reuse the members of your parent class. So, there is no need
to define the member again. So less code is required in the class.
Types Of Inheritance
Single inheritance
Multiple inheritance
Hierarchical inheritance
Multilevel inheritance
Hybrid inheritance
Single inheritance is defined as the inheritance in which a derived class is inherited from the
only one base class.
When one class inherits another class which is further inherited by another class, it is known as multi
level inheritance in C++. Inheritance is transitive so the last derived class acquires all the members of
all its base classes.
Hierarchical inheritance is defined as the process of deriving more than one class from a base
class.
Multiple inheritance is the process of deriving a new class that inherits the attributes from
two or more classes.
A class can also be derived from one class, which is already derived from another class.
In the following example, MyGrandChild is derived from class MyChild (which is derived
from MyClass).
C++ Hybrid Inheritance