KEMBAR78
Unit 1 Introduction | PDF | Computers
0% found this document useful (0 votes)
25 views29 pages

Unit 1 Introduction

oop

Uploaded by

Anupama Mishra
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
25 views29 pages

Unit 1 Introduction

oop

Uploaded by

Anupama Mishra
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 29

UNIT -1

Overview of C++ language

1. C++ can be considered as an incremental version of c language which consists all programming

language constructs with newly added features of object oriented programming.

2.c++ is structure(procedure) oriented and object oriented programming language.

3.The file extension of C++ program is “.CPP”

4. Function overloading and operator overloading are possible.

5. Variables can be declared in inline i.e when required

6. In c++ more emphasis is give on data rather than procedures

7.Polymorphism, encapsulation and inheritance are possible.

8. Data abstraction property is supported by c++.

9. Data access is limited. It can be accessed by providing various visibility modes both for data

and member functions. there by providing data security by data hiding

10.Dymanic binding is supported by C++

11..It supports all features of c language

12.It can be called as an incremental version of c language

Programming Paradigms

Let us go on a whirlwind tour of 4 different programming paradigms – Procedural, Object-Oriented,


Functional and Logical. This article will give you a better understanding of the various programming
paradigms.

1. Procedural Programming
Procedural Programming can also be referred to as imperative programming. It is a programming paradigm
based upon the concept of procedure calls, in which statements are structured into procedures (also known as
subroutines or functions). They are a list of instructions to tell the computer what to do step by step, Procedural
programming languages are known as top-down languages. Most of the early programming languages are all
procedural.
Examples of Fortran C and Cobol. Here is a sample code in COBOL.
Features of Procedural Code

 Procedural Programming is excellent for general-purpose programming


 The coded simplicity along with ease of implementation of compilers and interpreters
 A large variety of books and online course material available on tested algorithms, making it easier to
learn.
 The source code is portable
 The code can be reused in different parts of the program, without the need to copy it
 The program flow can be tracked easily as it has a top-down approach.

2. Logical Programming

Logical programming is a computer programming paradigm that has its foundations in mathematical logic in
which program statements express facts and rules about problems within a system. Rules are written as logical
clauses with a head and a body. They also follow a declarative rather than an imperative approach. However,
what does that mean?
To understand how a problem can be solved in logical programming, you need to know about the building
blocks − Facts and Rules −
Let us understand the difference between Imperative and declarative programming.
Imagine you walk into your favorite coffee place and you would like to order some coffee.
The imperative approach will be:

 Enter the coffee shop


 Queue in the line and wait for the barista asking you for your order
 Order
 Yes, for takeaway, please
 Pay
 Present your loyalty card to collect points
 Take your order and walk away

The declarative approach:

 A large latte for takeaway, please

So rather than providing a step by step instruction (imperative), you tell the system what you need and let it try
to come up with a solution (declarative).
Prolog follows the Logical paradigm and is probably the most famous language in the logical programming
family.
Prolog has been enormously influential in the domains of theorem proving, expert systems, natural language
processing and in the field of artificial intelligence (notably IBM’s Watson2) in general
Prolog, like SQL, has two main aspects, one to express the data and another to query it. The basic constructs of
logical programming, terms, and statements, are inherited from logic. There are three basic statements:

 Facts are fundamental assertions about the problem domain (e.g. "Socrates is a man")
 Rules are inferences about facts in the domain (e.g. "All men are mortal.")
 Queries are questions about that domain (e.g. "Is Socrates mortal?")

Features of Logical Programming

 Logical programming can be used to express knowledge in a way that does not depend on the
implementation, making programs more flexible, compressed and understandable.
 It enables knowledge to be separated from use, i.e. the machine architecture can be changed
without changing programs or their underlying code.

 It can be altered and extended in natural ways to support special forms of knowledge, such
as meta-level of higher-order knowledge.
It can be used in non-computational disciplines relying on reasoning and precise means of
expression.

3. Functional Programming
Functional programming is a programming paradigm where you have a style of building the structure and
elements of computer programs. Here you treat computation as an evaluation of mathematical functions and
you avoid changing-state and mutable data.
Functional programming consists only of PURE functions. So, what do you understand by Pure functions?
Pure functions are those which take an argument list as an input and whose output is a return value. Now you
may feel that all functions are pure as any function takes in values and returns a value.
For example, if a function relies on the global variable or class member’s data, then it is not pure. And in such
cases, the return value of that function is not entirely dependent on the list of arguments received as input and
can also have side effects. So, what do you understand by the term side effect? A side effect is a change in the
state of an application that is observable outside the called function other than its return value. For example:
Modifying any external variable or object property such as a global variable, or a variable in the parent
function scope chain.

4. Object-Oriented Programming(OOP):
In this framework, all real-world entities are represented by Classes. Objects are instances of classes so each
object encapsulates a state and behavior. State implies the fields, attributes of the object and behavior is what
you do with the state of the object and they are the methods. Objects interact with each other by passing
messages.
 Encapsulation – This is a fundamental feature of Object-Oriented Programming. Here you hide
unnecessary details in classes and deliver a simple and clear interface for working. It describes the idea
of bundling data and methods that work on that data within one unit. This concept is also often used to
hide the internal representation, or state, of an object from the outside
 Inheritance - Inheritance is one of the core concepts of object-oriented programming (OOP)
languages. It is a mechanism where you can derive a class from another class for a hierarchy of classes
that share a set of attributes and methods. It explains how the class hierarchies develop code readability
and support to the reuse of functionality.
 Data Abstraction - to Data abstraction is the reduction of a particular body of data to a simplified
representation of the whole. Data abstraction is usually the first step in database design.
 Polymorphism - Polymorphism is an object-oriented programming concept that refers to the ability of
a variable, function or object to take on multiple forms.

Programming languages that have implemented the OO paradigm are: Ruby, Java, C++, Python, Simula(the
first OOP language)

Features of object oriented programming:

1. Encapsulation

2. Data abstraction

3. Polymorphism

4. Inheritance

5. Dynamic binding

6. Message passing

Encapsulation: Wrapping of data and functions together as a single unit is known as encapsulation. By
default, data is not accessible to outside world and they are only accessible through the functions which are
wrapped in a class. Prevention of data direct access by the program is called data hiding or information hiding

Data abstraction :

Abstraction refers to the act of representing essential features without including the background details or
explanation. Classes use the concept of abstraction and are defined as a list of attributes such as size, weight,
cost and functions to operate on these attributes. They encapsulate all essential properties of the object that are
to be created. The attributes are called as data members as they hold data and the functions which operate on
these data are called as member functions.

Class use the concept of data abstraction so they are called abstract data type (ADT)

Polymorphism: Polymorphism comes from the Greek words “poly” and “morphism”. “poly” means many and
“morphism” means form i.e.. many forms. Polymorphism means the ability to take more than one form. For
example, an operation have different behavior in different instances. The behavior depends upon the type of
the data used in the operation.

Different ways to achieving polymorphism in C++ program:

1) Function overloading 2) Operator overloading

#include<iostream>

using namespace

std; int main()

{int a=4; a=a<<2;

cout<<”a=”<<a<<endl;

return 0;

Inheritance: Inheritance is the process by which one object can acquire the properties of another.
Inheritance is the most promising concept of OOP, which helps realize the goal of constructing software from
reusable parts, rather than hand coding every system from scratch. Inheritance not only supports reuse across
systems, but also directly facilitates extensibility within a system. Inheritance coupled with polymorphism and
dynamic binding minimizes the amount of existing code to be modified while enhancing a system. When the
class child, inherits the class parent, the class child is referred to as derived class (sub class) and the class
parent as a base class (super class). In this case, the class child has two parts: a derived part and an incremental
part. The derived part is inherited from the class parent. The incremental part is the new code written
specifically for the class child.

Dynamic binding:

Binding refers to linking of procedure call to the code to be executed in response to the call.

Dynamic binding(or late binding) means the code associated with a given procedure call in not known until the
time of call at run time.

Message passing:

An object oriented program consists of set of object that communicate with each other. Objects communicates
with each other by sending and receiving information.

A message for an object is a request for execution of a procedure and therefore invoke the function that is
called for an object and generates result

Benefits of object oriented programming (OOPs)


Reusability: In OOP‟ s programs functions and modules that are written by a user can be reused by

other users without any modification.

Inheritance: Through this we can eliminate redundant code and extend the use of existing classes.

Data Hiding: The programmer can hide the data and functions in a class from other classes. It helps the
programmer to build the secure programs.

Reduced complexity of a problem: The given problem can be viewed as a collection of different objects.
Each object is responsible for a specific task. The problem is solved by interfacing the objects. This technique
reduces the complexity of the program design.

Easy to Maintain and Upgrade: OOP makes it easy to maintain and modify existing code as new objects

can be created with small differences to existing ones. Software complexity can be easily managed.

Message Passing: The technique of message communication between objects makes the interface

with external systems easier.

Modifiability: it is easy to make minor changes in the data representation or the procedures in an

OO program. Changes inside a class do not affect any other part of a program, since the only

public interface that the external world has to a class is through the use of methods.

BASIC STRUCTURE OF C++ LANGUAGE :

The program written in C++ language follows this basic structure. The sequence of sections should be as they
are in the basic structure. A C program should have one or more sections but the sequence of sections is to be
followed.

1. Documentation section

2. Linking section
3. Definition section

4. Global declaration section & class declarations

5.Member function definition

6. Main function section

main()

Declaration section

Executable section

1. DOCUMENTATION SECTION : comes first and is used to document the use of logic or reasons in your
program. It can be used to write the program's objective, developer and logic details. The documentation is
done in C language with /* and */ . Whatever is written between these two are called comments.

2. LINKING SECTION : This section tells the compiler to link the certain occurrences of keywords or
functions in your program to the header files specified in this section.

e.g. #include<iostream>

using namespace std; directive causes the preprocessor to add the contents of the iostream file to the program.
It contains declarations for cout and cin.

cout is a predefined object that represents the standard output stream.

The operator << is an insertion operator, causes the string in double quotes to be displayed on the screen.

cout << “C++”;

The statement cin>>n; is an input statement and causes the program to wait for the user to type in a

number. The number keyed is placed on the variable “n”. The identifier cin is a predefined object in C++
that corresponds to the standard input stream. The operator >> is known as extraction operator. It extractsthe
value from the keyboard and assigns it to the value variable on its right.

cin >> 45.5

3. DEFINITION SECTION : It is used to declare some constants and assign them some value.

e.g. #define MAX 25

Here #define is a compiler directive which tells the compiler whenever MAX is found in the program replace it
with 25.

4. GLOBAL DECLARATION SECTION : Here the variables and class definations which are used

throughout the program (including main and other functions) are declared so as to make them global(i.e

accessible to all parts of program).

A CLASS is a collection of data and functions that act or manipulate the data. The data components of a class
are called data members and function components of a class are called member functions

A class also termed as a blue print or prototype that defines the variable or functions common to all objects of
certain kind. It is a user defined data type.

e.g.

int i; //this declaration is done outside and before main()

5. SUB PROGRAM OR FUNCTION SECTION : This has all the sub programs or the functions which our
program needs.

void display()

cout<<”C++ is better that C”;

SAMPLE C++ PROGRAM:

#include<iostream>
using namespace std;

void display()

cout<<”C++ is better that C”;

int main()

display()

return 0;

6. MAIN FUNCTION SECTION : It tells the compiler where to start the execution from.

main()

main function has two sections

1. declaration section : In this the variables and their data types are declared.

2. Executable section or instruction section : This has the part of program which actually performs the task we
need.

namespace:

namespace is used to define a scope that could hold global identifiers.

ex:-namespace scope for c++ standard library.

A classes ,functions and templates are declared within the namespace named std using namespace std;--
>directive can be used.
user defined name space:

syntax for defining name space :

namespace namespace_name

//declarations of variables.functions,classes etc...

ex:

#include<iostream>

using namespace std;

namespace sample

{`

int m;

void display(int n)

cout<<"in namespace N="<<n<<endl;

using namespace sample;

int main()

int a=5;

m=100;

display(200);

cout<<"M in sample name space:"<<sample::m;

return 0;}
#include<iostream>

This directive causes the preprocessor to add content of iostream file to the program. some old versions of C++
used iostream.h .if complier does not support ANSI (american nation standard institute) C++ then use header
file iostream.h

Scope Resolution operator:

Scope:-Visibility or availability of a variable in a program is called as scope. There are two types of scope.

i)Local scope ii)Global scope

Local scope: visibility of a variable is local to the function in which it is declared.

Global scope: visibility of a variable to all functions ofa program Scope resolution operator in “::” .

This is used to access global variables if same variables are declared as localand global

PROGRAM

#include<iostream.h>

int a=5;

void main()

int a=10;

cout<<”Local a=”<<a<<endl;

cout<<”Global a=”<<::a<<endl;

Expected output:

Local a=10

Global a=5

Program to find sum of n natural numbers */


#include<iostream.h>

int main()

int i = 1,sum = 0,n;

cout<<"Enter N"<<end;

cin>>n;

while(i<=n)

sum = sum + i;

i = i + 1;

cout<<”Sum of first”<<n<”natural numbers

is:”<<sum<<endl; return 0;

Introduction of Class:

An object oriented programming approach is a collection of objects and each object consists of

corresponding data structures and procedures. The program is reusable and more maintainable.

The important aspect in oop is a class which has similar syntax that of structure.

class: It is a collection of data and member functions that manipulate data. The data components of class
arecalled data members and functions that manipulate the data are called member functions.

It can also called as blue print or prototype that defines the variables and functions common toall objects of
certain kind. It is also known as user defined data type or ADT(abstract data type) A classis declared by the
keyword class.

Syntax:-

class class_name
{

Access specifier :

Variable declarations;

Access specifier :

function declarations;

};

Access Control:

Access specifier or access modifiers are the labels that specify type of access given to members of a

class. These are used for data hiding. These are also called as visibility modes. There are three types of

access specifiers:

1.private

2.public

3.protected

1.Private:

If the data members are declared as private access then they cannot be accessed from otherfunctions outside the
class. It can only be accessed by the functions declared within the class. It is declared by the key word
“private” .

2.public:

If the data members are declared public access then they can be accessed from other functions outside the
class. It is declared by the key word “public” .

3.protected:
The access level of protected declaration lies between public and private. This accessspecifier is used at the
time of inheritance

Note:-

If no access specifier is specified then it is treated by default as private. The default access specifier of
structure is public where as that of a class is “private”

Example:

class student

private : int roll;

char name[30];

public:

void get_data()

cout<<”Enter roll number and name”:

cin>>roll>>name;

void put_data()

cout<<”Roll number:”<<roll<<endl;

cout<<”Name :”<<name<<endl;

};

Object:-Instance of a class is called object.

Syntax:

class_name object_name;
Ex:

student s;

Accessing members:-dot operator is used to access members of class

Object-name.function-name(actual arguments);

Ex:

s.get_data();

s.put_data();

Note:

1.If the access specifier is not specified in the class the default access specifier is private

2.All member functions are to be declared as public if not they are not accessible outside the class.

Instance of a class is called as object.

Syntax:

Class_name object name;

Example:

student s;

in the above example s is the object. It is a real time entity that can be used.

Write a program to read data of a student

#include<iostream>

using namespace std;

class student
{

private:

int roll;

char name[20];

public:

void getdata()

{cout<<”Enter Roll number:”;

cin>>roll;

cout<<”Enter Name:”;

cin>>name;

void putdata()

{cout<<”Roll no:”<<roll<<endl;

cout<<Name:”<<name<<endl;

};

int main()

student s;

s.getdata();

s.putdata();

returm 0;

Scope Resolution operator:

Scope:-Visibility or availability of a variable in a program is called as scope. There are two


types of scope. i)Local scope ii)Global scope

Local scope: visibility of a variable is local to the function in which it is declared.

Global scope: visibility of a variable to all functions of a program

Scope resolution operator in “::” .

This is used to access global variables if same variables are declared as local and global

#include<iostream.h>

int a=5;

void main()

int a=1;

cout<<”Local a=”<<a<<endl;

cout<<”Global a=”<<::a<<endl;

Class Scope:

Scope resolution operator(::) is used to define a function outside a class.

#include <iostream>

using namespace std;

class sample

public:

void output(); //function declaration

};

// function definition outside the

class void sample::output() {

cout << "Function defined outside the class.\n";

};
int main() {

sample obj;

obj.output();

return 0;

Output of program:

Function defined outside the class.

Write a program to find area of rectangle

#include<iostream.h>

class rectangle

int L,B;

public:

void get_data();

void area();

};

void rectangle::get_data()

cout<<”Enter Length of rectangle”;

cin>>L;

cout<<”Enter breadth of rectangle”;

cin>>B;

int rectangle::area()
{

return L*B;

int main()

rectangle r;

r.get_data();

cout<<”Area of rectangle is”<<r.area();

return 0;

Array of objects:

Class_name object_name[size];

Where size is the size of array

Ex:

Myclass obj[10];

Write a program to initialize array of objects and print them

#include<iostream>

using namespace std;

class MyClass

int a;

public:

void set(int x)

a=x;
}

int get()

return a;

};

int main()

MyClass obj[5];

for(int i=0;i<5;i++)

obj[i].set(i);

for(int i=0;i<5;i++)

cout<<"obj["<<i<<"].get():"<<obj[i].get()<<endl;

Output:

obj[0].get():0

obj[1].get():1

obj[2].get():2

obj[3].get():3

obj[4].get():4

Objects as Function Arguments: Objects can be used as arguments to

functions This can be done in three ways

a. Pass-by-value or call by value

b. Pass-by-address or call by address

c. Pass-by-reference or call by reference


a.Pass-by-value – A copy of object (actual object) is sent to function and assigned to the object of called

function (formal object). Both actual and formal copies of objects are stored at different memory

locations. Hence, changes made in formal object are not reflected to actual object.

write a program to swap values of two objects

#include<iostream.h>

using namespace std;

class sample2;

class sample1

int a;

public:

void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 x,sample2 y);

};

void sample1::getdata(int x)

a=x;

class sample2

int b;

public:
void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 x,sample2 y);

};

void sample2::getdata(int x)

b=x;

void display(sample1 x,sample2 y)

cout<<"Data in object 1 is"<<endl;

cout<<"a="<<x.a<<endl;

cout<<"Data in object 2 is"<<endl;

cout<<"b="<<y.b<<endl;

void swap(sample1 x,sample2 y)

int t;

t=x.a;

x.a=y.b;

y.b=t;

int main()

sample1 obj1;

sample2 obj2;
obj1.getdata(5);

obj2.getdata(15);

cout<<"Before Swap of data between Two objects\n

"; display(obj1,obj2);

swap(obj1,obj2);

cout<<"after Swap of data between Two objects\n ";

display(obj1,obj2);

Before Swap of data between Two objects

Data in object 1 is a=5

Data in object 2 is b=15

after Swap of data between Two objects

Data in object 1 is a=5

Data in object 2 is b=15

b. Pass-by-address: Address of the object is sent as argument to function.

Here ampersand(&) is used as address operator and arrow (->) is used as de referencing

operator. If any change made to formal arguments then there is a change to actual arguments

write a program to swap values of two objects

#include<iostream.h>

using namespace std;

class sample2;

class sample1

int a;
public:

void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 *x,sample2 *y);

};

void sample1::getdata(int x)

a=x;

class sample2

int b;

public:

void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 *x,sample2 *y);

};

void sample2::getdata(int x)

b=x;

void display(sample1 x,sample2 y)

cout<<"Data in object 1 is"<<endl;

cout<<"a="<<x.a<<endl;

cout<<"Data in object 2 is"<<endl;


cout<<"b="<<y.b<<endl;

void swap(sample1 *x,sample2 *y)

int t;

t=x->a;

x->a=y->b;

y->b=t;

int main()

sample1 obj1;

sample2 obj2;

obj1.getdata(5);

obj2.getdata(15);

cout<<"Before Swap of data between Two objects\n ";

display(obj1,obj2);

swap(&obj1,&obj2);

cout<<"after Swap of data between Two objects\n ";

display(obj1,obj2);

Before Swap of data between Two objects

Data in object 1 is a=5

Data in object 2 is b=15

after Swap of data between Two objects


Data in object 1 is a=15

Data in object 2 is b=5

c.Pass-by-reference:A reference of object is sent as argument to function.

Reference to a variable provides alternate name for previously defined variable. If any change made to

reference variable then there is a change to original variable.

A reference variable can be declared as follows:

Datatype & reference variable =variable;

Ex:

int x=5;

int &y=x;

Write a program to find sum of n natural numbers using reference variable

#include<iostream.h>

using namespace std;

int main()

int i=0;

int &j=i;

int s=0;

int n;

cout<<"Enter n:";

cin>>n;

while(j<=n)

s=s+i;
i++;

cout<<"sum="<<s<<endl;

Output:

Enter n:10

sum=55

write a program to swap values of two objects

#include<iostream.h>

using namespace std;

class sample2;

class sample1

int a;

public:

void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 &x,sample2 &y);

};

void sample1::getdata(int x)

a=x;

class sample2
{

int b;

public:

void getdata(int x);

friend void display(sample1 x,sample2 y);

friend void swap(sample1 &x,sample2 &y);

};

void sample2::getdata(int x)

b=x;

void display(sample1 x,sample2 y)

cout<<"Data in object 1 is"<<endl;

cout<<"a="<<x.a<<endl;

cout<<"Data in object 2 is"<<endl;

cout<<"b="<<y.b<<endl;

void swap(sample1 &x,sample2 &y)

int t;

t=x.a;

x.a=y.b;

y.b=t;

int main()
{

sample1 obj1;

sample2 obj2;

obj1.getdata(5);

obj2.getdata(15);

cout<<"Before Swap of data between Two objects\n ";

display(obj1,obj2);

swap(obj1,obj2);

cout<<"after Swap of data between Two objects\n ";

display(obj1,obj2);

Output:

Before Swap of data between Two objects

Data in object 1 is a=5

Data in object 2 is b=15

after Swap of data between Two objects

Data in object 1 is a=15

Data in object 2 is b=5

You might also like