0% found this document useful (0 votes)
77 views

285 - OOPS Lecture Notes Complete

285_OOPS lecture notes Complete

Uploaded by

au9t5teyr
Copyright
© © All Rights Reserved
Available Formats
Download as PDF or read online on Scribd
0% found this document useful (0 votes)
77 views

285 - OOPS Lecture Notes Complete

285_OOPS lecture notes Complete

Uploaded by

au9t5teyr
Copyright
© © All Rights Reserved
Available Formats
Download as PDF or read online on Scribd
You are on page 1/ 146
Object Oriented Programming Using C++ LECTURE NOTES ON Object Oriented Programming Using C++ Prepared by Dr. Subasish Mohapatra Department of Computer Science and Application College of Engineering and Technology, Bhubaneswar Biju Patnaik University of Technology, Odisha SYLLABUS: pccs2207 Object Oriented Programming Module | Introduction to object oriented programming, user defined types, structures, unions, polymorphism, encapsulation. Getting started with C++ syntax, data-type, variables, strings, functions, default values in functions, recursion, namespaces, operators, flow control, arrays and pointers. Module Il Abstraction mechanism: Classes, private, public, constructors, destructors, member data, member functions, inline function, friend functions, static members, and references. Inheritance: Class hierarchy, derived classes, single inheritance, multiple, multilevel, hybrid inheritance, role of virtual base class, constructor and destructor execution, base initialization using derived class constructors. Polymorphism: Binding, Static binding, Dynamic binding, Static polymorphism: Function Overloading, Ambiguity in function overloading, Dynamic polymorphism: Base class pointer, object slicing, late binding, method overriding with virtual functions, pure virtual functions, abstract classes. Operator Overloading: This pointer, applications of this pointer, Operator function, member and non member operator function, operator overloading, I/O operators. Exception handling: Try, throw, and catch, exceptions and derived classes, function ‘exception declaration, unexpected exceptions, exception when handling exceptions, resource capture and release. Module ttt Dynamic memory management, new and delete operators, object copying, copy constructor, assignment operator, virtual destructor. Template: template classes, template functions. Standard Template Library: Fundamental idea about string, iterators, hashes, iostreams and other types. Namespaces: user defined namespaces, namespaces provided by library. Object Oriented Design, design and programming, role of classes. Text Books: 1. Object Oriented Programming with C++ by E. Balagurusamy, McGraw-Hill Education (India) 2. ANSI and Turbo C++ by Ashoke N. Kamthane, Pearson Education Reference Books: 1.Big C++ - Wiley India 2.C++: The Complete Reference- Schildt, McGraw-Hill Education (India) 3. C++ and Object Oriented Programming — Jana, PHI Learning 4. Object Oriented Programming with C++ - Rajiv Sahay, Oxford 5. Mastering C++ - Venugopal, McGraw-Hill Education (India) 3 PTC Lecture 01 Lecture 02: Lecture 03: Lecture 04: Lecture 05: Lecture 06 Lecture 07: Lecture 08: Lecture 09 Lecture 10 Lecture 11 Lecture 12: Lecture 13: Lecture 14: Lecture 15: Lecture 16: Lecture 17: Lecture 18 Lecture 19: Lecture 20: Lecture 21 Lecture 22 &23: Lecture 24: Lecture 25: Lecture 26 Lecture 27 Lecture 28: Lecture 29 Lecture 30 Lecture 31: Lecture 32: Lecture 33: Lecture 34: Lecture Lecture 36 Lecture 37: Lecture 38 Lecture 39: Lecture 40: Lecture 41 Lecture 42: CONTENTS Introduction Object Oriented Programming BASIC CONCEPTS OF OBIE BENEFITS OF OOP Basies of C++ Tokens Basic Data types in C++ Symbolic Constant Operators Control Structures Functions in C++ Function Overloading Class Member Function Nesting of Member function Array with Class Static Data Member Friendly fnctions Returning Objects Constructors Destructors Operator Overloading Type Conversion Class to Basie type Inheritance Muhtilevel Inheritance Hierarchical Inheritance Virtual Base Class Polymorphism Virtual functions Pure Virtual Funetions (C+ funetion overriding Exception Handling Array reference out of bound Containership in C++ Template Class Template Virtual destructors Managing Console 10 Namespaces, New & Delete Operators “TS ORIENTED PROGRAMMING PTC Module-1: LECTURE-1 Introduction: Programmers write instructions in various programming languages to perform their computation tasks such as: (Machine level Language (ii) Assembly level Language (iil) High level Language Machine level Language : Machine code or machine language is a set of instructions executed directly by a computer's central processing unit (CPU). Each instruction performs a very specific task, such as a load, a jump, or an ALU operation on a unit of data in a CPU register or memory. Every program directly executed by a CPU is made up of a series of such instructions. Assembly level Language : An assembly language (or assembler language) is a low-level programming language for a computer, or other programmable device, in which there is a very strong (generally one-to-one) correspondence between the language and the architecture's machine code instructions. Assembly language is converted into executable machine code by a utility program referred to as an assembler; the conversion process is referred to as assembly, or assembling the code. High level Language : High-level language is any programming language that enables development of a program in much simpler programming context and is generally independent of the computer's hardware architecture. High-level language has a higher level of abstraction from the computer, and focuses more on the programming logic rather than the underlying hardware components such as memory addressing and register utilization, The first high-level programming languages were designed in the 1950s. Now there are dozens of different languages, including Ada , Algol, BASIC, COBOL, C, C++, JAVA, FORTRAN, LISP, Pascal, and Prolog. Such languages are considered high-level because they are closer to human languages and farther from machine languages. In contrast, assembly languages are considered low- level because they are very close to machine languages. The high-level programming languages are broadly categorized in to two categories: (iv) Procedure oriented programming(POP) language (¥) Object oriented programming(OOP) language. PTC Procedure Oriented Programming Language In the procedure oriented approach, the problem is viewed as sequence of things to be done such as reading , calculation and printing, Procedure oriented programming basically consist of writing a list of instruction or actions for the computer to follow and organizing these instruction into groups known as functions, Main program i Function-1 Function-2 Funetion-3 ‘The disadvantage of the procedure oriented programming languages is: 1. Global data access 2 It does not model real word problem very well 3. No data hiding Global data Global data Function-1 Funetion-2 Funetion-3 Local data Local data Local data Characteristics of procedure oriented programming: Emphasis is on doing things(algorithm) Large programs are divided into smaller programs known as functions. Most of the functions share global data Data move openly around the system from function to function Function transforms data from one form to another. 6. Employs top-down approach in program design 6 PTC Object Oriented Programing “Object oriented programming as an approach that provides a way of modularizing programs by creating partitioned memory area for both data and functions that can be used as templates for creating copies of such modules on demand”. Object A Object B Data Data Functions [+ *{_ Functions Object C inctions Data Features of the Object Oriented programming Emphasis is on doing rather than procedure. programs are divided into what are known as objects. Data structures are designed such that they characterize the objects. Functions that operate on the data of an object are tied together in the data structure. Data is hidden and can’t be accessed by external functions, Objects may communicate with each other through functions. New data and functions can be easily added. Follows bottom-up approach in program design. 7 PTC LECTURE-3 BASIC CONCEPTS OF OBJ} 'S ORI ‘TED PROGRAMMIN! Objects Classes Data abstraction and encapsulation Inheritance Polymorphism Dynamic binding Message passing OBJECTS Objects are the basic run-time entities in an object-oriented system. They may represent a person, a place, a bank account, a table of data or any item that the program must handle. The fundamental idea behind object oriented approach is to combine both data and function into a single unit and these units are called objects. The term objects means a combination of data and program that represent some real word entity. For example: consider an example named Amit; Amit is 25 years old and his salary is 2500. ‘The Amit may be represented in a computer program as an abject. The data part of the object would be (name: Amit, age: 25, salary: 2500) The program part of the object may be collection of programs (retrive of data, change age, change of salary). In general even any user —defined type-such as employee may be used. In the Amit object the name, age and salary are called attributes of the object. Object: Student STUDENT DATA Total Name Date-of-birth, Marks FUNCTIONS Total Average Display Display l CLAS: A group of objects that share common properties for data part and some program part are collectively called as class. In C ++ a class is @ new data type that contains member variables and member functions that ‘operate on the variabi 8 PTC DATA ABSTRACTION Abstraction refers to the act of representing essential features without including the back ‘ground details or explanations. Classes use the concept of abstraction and are defined as size, width and cost and functions to operate on the attributes. DATA ENCAPSALATION The wrapping up of data and function into a single unit (called class) is known as encapsulation, The data is not accessible to the outside world and only those functions which are wrapped in the class can access it. These functions provide the interface between the objects data and the program, INHERITENCE, Inheritance is the process by which objects of one class acquire the properties of another class. In the concept of inheritance provides the idea of reusablity. This mean that we can add additional features to an existing class with out modifying it. This is possible by desining a new class will have the combined features of both the classes. POLYMORPHISIM: Polymorphism means the ability to take more than one form. An operation may exhibit different instance. The behaviour depends upon the type of data used in the operation. A language feature that allows a function or operator to be given more than one definition. ‘The types. of the arguments with which the function or operator is called determines which definition will be used Overloading may be operator overloading or function overloading, It is able to express the operation of addition by a single operater say “+”. When this is possible you use the expression x + y to denote the sum of x and y, for many different types of x and y; integers , float and complex no, You can even define the + operation for two strings to mean the concatenation, of the strings. Binding refers to the linking of a procedure call to the code to the executed in response to the call. Dynamic binding means the code associated with a given procedure call is not known untill the time of the call at run-time. It is associated with a polymorphic reference depends upon the dynamic type of that reference 9 PTC SSAGE PASSING An object oriented program consists of a set of objects that communicate with cach other. ‘A message for an object is a request for execution of a procedure and therefore will invoke a function (procedure) in the receiving object that generates the desired result. Message passing involves specifying the name of the object, the name of the function (message) and information to be sent. Employee . Salary (name) Object Information Message 10 PTC LECTURE- 4 BENEFITS OF OOP: ‘oriented contributes to Oop offers several benefits to both the program designer and the user. Obje the solution of many problems associated with the development and quality of software products. The principal advantages are 1. Through inheritance we can eliminate redundant code and extend the use of existing classes. 2. We can build programs from the standard working modules that communicate with one another, rather than having to start writing the code from scratch, This leads to saving of development time and higher productivity This principle of data hiding helps the programmer to build secure programs that can’t be invaded by code in other parts of the program. is possible to have multiple instances of an object to co-exist with out any interference. It is easy to partition the work in a project based on objects. Object-oriented systems can be easily upgraded from small to large systems, Message passing techniques for communication between objects makes the interface description with external systems much simpler. 8. Software complexity can be easily managed. 4. 5 6 7. APPLICATION OF OOP: ‘The most popular application of oops up to now, has been in the area of user interface design such as windows. There are hundreds of windowing systems developed using oop techniques. Real business systems are often much more complex and contain many more objects ‘with complicated attributes and methods. Oop is useful in this type of applications because it can simplify a complex problem. The promising areas for application of oop includes. Real - Time systems. Simulation and modeling Object oriented databases. Hypertext,hypermedia and expertext, Al and expert systems Neural networks and parallel programming, Dicision support and office automation systems. CIM / CAM/ CAD system. u PTC LECTURE-S of CH C ++ is an object oriented programming language, C 11 was developed by Jarney Stroustrup at AT & T Bell lab, USA in carly eighties. C ++ was developed from c and simula 67 language. C ++ was early called “C with classes’ C++ Comments: C+ introduces a new comment symbol //(double slash). Comments start with a double slash symbol and terminate at the end of line, A comment may start any where in the line and what ever follows till the end of line is ignored. Note that there is no closing symbol, The double slash comment is basically a single line comment. Multi line comments can be written as follows: Ji this is an example of JicH program thank you The ¢ comment symbols /* ....*/ are still valid and more suitable for multi line comments. /* this is an example of c++ program */ Qutput Operato The statement cout <="Hello, world” displayed the string with in quotes on the screen. The identifier cout can be used to display individual characters, strings and even numbers. It is a predefined object that corresponds to the standard output stream, Stream just refers to @ flow of data and the standard ‘Output stream normally flows to the screen display. The cout object, whose properties are defined in jostream.h represents that stream, The insertion operator << also called the ‘put to” operator directs the information on its right to the object on its lef. Return Statement: In C+ main () returns an integer type value to the operating system. Therefore every main ( "++ should end with a return (0) statement, otherwise a warning or an error might occur. Input Operator The statement cin>> number 1; is an input statement and causes. The program to wait for the user to type in a number. The number keyed in is placed in the variable numberl. The identifier ein is a predefined object in C+ that corresponds to the standard input stream, Here this stream represents the key board. The operator >> is known as get from operator. It extracts value from the keyboard and assigns it to the variable on its right. 12 PTC Cascading Of VO Operator cout<<"sum="*<>numberl>>number2; Structure Of A Pro} Probably the best way to start learning a programming language is by writing a program. Therefore, here is our fitst program: i my first program in C++ +#include using namespace std; int main () cout << "Hello World!" return 0; 3 Output:-Hello World! The first panel shows the source code for our first program. The second one shows the result of the program once compiled and executed. The way to edit and compile a program depends on the compiler you are using. Depending on whether it has a Development Interface or not and on its version, Consult the compilers section and the manual or help included with your compiler if you have doubts on how to compile a C++ console program. ‘The previous program is the typical program that programmer apprentices write for the first time, and its result is the printing on screen of the "Hello World!" sentence. It is one of the simplest programs that can be written in C++, but it already contains the fundamental components that every (C++ program has, We are going to look line by line at the code we have just written: i my first program in C++ ‘This is a comment line, All lines beginning with two slash signs (i) are considered comments and do not have any effect on the behavior of the program. The programmer can use them to include short explanations or observations within the source code itself. In this case, the line is a brief description ‘of what our program is. #include Lines beginning with a hash sign (#) are directives for the preprocessor. They are not regular code lines with expressions but indications for the compiler’s preprocessor. In this case the directive itinclude tells the preprocessor to include the iostream standard file. This specific file (ostream) includes the declarations of the basic standard input-output library in C++, and it is included because its functionality is going to be used later in the program. using namespace std; All the elements of the standard C-++ library are declared within what is called a namespace, the namespace with the name std. So in order to access its functionality we declare with this expression that we will be using these entities. This line is very frequent in C++ programs that use the standard library, and in fact it will be included in most of the source codes included in these tutorials. ;onds to the beginning of the definition of the main function, The main function is the point by where all C++ programs start their execution, independently of its location within the source code. It does not matter whether there are other functions with other names defined before or after it— the instructions contained within this function’s definition will always be the first ones to be 13 PTC ‘executed in any C+ program, For that same reason, it is essential that all C++ programs have a main function, ‘The word main is followed in the code by a pair of parentheses (()). That is because it is a function declaration: In C++, what differentiates a function declaration from other types of expr these parentheses that follow its name. Optionally, these parentheses may enclose a list of parameters within them, Right after these parentheses we can find the body of the main function enclosed in braces ({}). What is contained within these braces is what the function does when it is executed. cout << "Hello World!"; This line is a C++ statement. A statement is a simple or compound expression that can actually produce some effect. In fact, this statement performs the only action that generates a visible effect in ‘our first program, cout represents the standard output stream in C++, and the meaning of the entire statement is to insert a sequence of characters (in this case the Hello World sequence of characters) into the standard ‘output stream (which usually is the sereen). cout is declared in the iostream standard file within the std namespace, so that’s why we needed to include that specific file and to declare that we were going to use this specific namespace earlier in our code. Notice that the statement ends with a semicolon character (;). This character is used to mark the end of the statement and in fact it must be included at the end of all expression statements in all C++ programs (one of the most common syntax errors is indeed to forget to include some semicolon after a statement) return 0; ‘The return statement causes the main function to finish. return may be followed by a return code (in ‘our example is followed by the return code 0). A retum code of 0 for the main function is generally interpreted as the program worked as expected without any errors during its execution. This is the ‘most usual way to end a C++ console program, You may have noticed that not all the lines of this program perform actions when the code is executed. There were lines containing only comments (those beginning by //). There were lines with directives for the compiler's preprocessor (those beginning by #). Then there were lines that began the declaration of a function (in this case, the main function) and, finally lines with statements (like the insertion into cout), which were all included within the block delimited by the braces ({}) of the main function. The program has been structured in different lines in order to be more readable, but in C++, we do not have strict rules on how to separate instructions in different lines, For example, instead of int main () { cout <<" Hello World!"; return 0; 3 We could have written: int main () { cout << "Hello World!" return 0; } Allin just one line and this would have had exactly the same meaning as the previous code. In C+, the separation between statements is specified with an ending semicolon (;) at the end of each one, so the separation in different code lines does not matter at all for this purpose. We can write many statements per line or write a single statement that takes many code lines. The division of 14 PTC code in different lines serves only to make it more legible and schematic for the humans that may read it Let us add an additional instruction to our first program: #i my second program in C++ +#include using namespace std; int main () cout << "Hello World! "; cout << "I'm a C+ program"; return 0; } ‘Output:-Hello World! I'm a C+ program In this case, we performed two insertions into cout in two different statements. Once again, the separation in different lines of code has been done just to give greater readability to the program, since main could have been perfectly valid defined this way: int main () t cout <<" Hello World! "; cout <<" I'ma CH program"; return 0; } We were also free to divide the code into more lines if we considered it more convenient int main () { cout << "Hello World!"; cout << "I'm a C+ program"; return 0; 3 And the result would again have been exactly the same as in the previous examples. Preprocessor directives (those that begin by ##) are out of this general rule since they are not statements. They are lines read and processed by the preprocessor and do not produce any code by themselves. Preprocessor directives must be specified in their own line and do not have to end with a semicolon (;). STRUCTURE OF C++ PROGRAM © Include files © Class declaration ‘© Class functions, definition © Main function program Exampl # inelude class person 15 PTC { char name|30}; int age; publi void getdata(void); void display(void); void persor { getdata (void) cout<<"enter name”; cin>>name; cout<<"enter age”; cin>>age; } void display() { cout<<"\n name:"<>x; sum=sum+x t float average; average-sum/x; cout< extraction operator scope resolution operator us pointer to member declarator * pointer to member operator * pointer to member operator Delete memory release operator Endl line feed operator New ‘memory allocation operator Setw field width operator SCOPE RESOLUTION OPERATO! Like C,C+ is also a block-structured language. Block -structured language. Blocks and scopes can be used in constructing programs. We know same variables can be declared in diffe blocks because the variables declared in blocks are local to that function, Blocks in C+ are often nested, Example: Block? Block1 } «_____] Block2 contained in block | .Note that declaration in an inher block hides a declaration of the same Variable in an outer block and therefore each declaration of x causes it to refer to a different data object. With in the inner block the variable x will refer to the data object declared there in, 25 PTC In Cthe global version of a variable can't be accessed from with in the inner block. (C++ resolves this problem by introducing a new operator =: called the scope resolution operator used to uncover a hidden variable. Syntax: : Variable name; Example: Hinclude < #include inline float mul(float x, float y) { } inline double div(double p.double q) { } return(x*y); return(p/a); main( ) float =12.345; float b=9.82; cout< #include mainQ { float amount; float value(float p,int n,float r-0.15); void printline(char ch="*,int len=40); printline(); amount=value(5000.00,5); cout<<"\n final value="< class item { cout<>ml; cout<<"enter 2nd subject mark:”; cin>>m2; void marks: :displaydata() ‘ cout<<"Ist subject mark:”< class set { int mn; public: void input(void); void display (void); void largest(void); B int set=largest (void) { iffm>n) return m; else return n; } void set::input(void) { cout<<"input values of mand n:”; cin>>m>>n; void set::display( void) { cout<<"largestvalue=" 3 void main() {