700 likes | 805 Vues
Learn about inheritance in object-oriented design through class examples, illustrating code reuse and customization capabilities. Explore a simple base class, derived classes, and object declarations.
 
                
                E N D
Inheritance Example -- Class.zip • One reason to use inheritance is that it permits you to reuse code from a previous project, but gives you the flexibility to slightly modify it if the old code doesn't do exactly what you need for the new project. • It doesn't make sense to start every new project from scratch since some code will certainly be repeated in several programs and you should strive to build on what you did previously.
INHERITANCE A SIMPLE CLASS TO START WITH Example program ------> VEHICLE.H
VEHICLE.H • It consists of four simple methods which can be used to manipulate data pertaining to our vehicle. • We will eventually refer to this as a base class or parent class.
THE IMPLEMENTATION FOR VEHICLE Example program ------> VEHICLE.CPP • The initialize() method assigns the values input as parameters to the wheels and weight variables. • We have methods to return the number of wheels and the weight, and finally, we have one that does a trivial calculation to return the loading on each wheel.
USING THE VEHICLE CLASS Example program ------> TRANSPRT.CPP • Inheritance uses an existing class and adds functionality to it to accomplish another, possibly more complex job. • It declares four objects of the vehicle class, initializes them, and prints out a few of the data values to illustrate that the vehicle class can be used as a simple class because it is a simple class. We are referring to it as a simple class as opposed to calling it a base class or derived class as we will do next.
OUR FIRST DERIVED CLASS Example program ------> CAR.H • The vehicle class is inherited due to the ": public vehicle" added to line 7. • This derived class named car is composed of all of the information included in the base class vehicle, and all of its own additional information. • Even though we did nothing to the class named vehicle, we made it into a base class because of the way we are using it here.
OUR FIRST DERIVED CLASS Example program ------> CAR.H • To go a step further, even though it will be used as a base class in an example program later, there is no reason it cannot continue to be used as a simple class in the previous example program. • In fact, it can be used as a simple class and a base class in the same program. The question of whether it is a simple class or a base class is answered by the way it is used.
OUR FIRST DERIVED CLASS Example program ------> CAR.H • In this case, the vehicle base class can be used to declare objects that represent trucks, cars, bicycles, or any number of other vehicles you can think up. • The class named car however can only be used to declare an object that is of type car because we have limited the kinds of data that can be intelligently used with it. • The car class is therefore more restrictive and specific than the vehicle class. The vehicle class is more general than the car class.
OUR FIRST DERIVED CLASS Example program ------> CAR.H • If we wished to get even more specific, we could define a derived class using car as the base class, name it sports_car, and include such information as red_line_limit for the tachometer which would be silly for the family station wagon. • The car class would therefore be used as a derived class and a base class at the same time, so it should be clear that these names refer to how a class is used.
HOW DO WE DECLARE A DERIVED CLASS? • A derived class is defined by including the header file for the base class as is done in line 5, then the name of the base class is given following the name of the derived class separated by a colon as is illustrated in line 7. • All objects declared as being of class car therefore are composed of the two variables from the class vehicle because they inherit those variables, and the single variable declared in the class car named passenger_load.
HOW DO WE DECLARE A DERIVED CLASS? • An object of this class will have three of the four methods of vehicle and the two new ones declared here. • The method named initialize() which is part of the vehicle class will not be available here because it is hidden by the local version of initialize() which is a part of the car class. • The local method will be used if the name is repeated allowing you to customize your new class.
Information Hiding • Note that the implementation for the base class only needs to be supplied in its compiled form. • The source code for the implementation can be hidden for economic reasons to aid software developers. • Hiding the source code also allows the practice of information hiding. The header for the base class must be available as a text file since the class definitions are required in order to use the class.
THE CAR CLASS IMPLEMENTATION Example program ------> CAR.CPP • The first thing you should notice is that this file has no indication of the fact that it is a derived class of any other file, that can only be determined by inspecting the header file for the class. • Since we can't tell if it is a derived class or not, it is written in exactly the same way as any other class implementation file.
ANOTHER DERIVED CLASS Example program ------> TRUCK.H • This class adds two more variables and three more methods. • A very important point that must be made is that the car class and the truck class have absolutely nothing to do with each other, they only happen to be derived classes of the same base class or parent class as it is sometimes called.
Example program ------> TRUCK.H • Note that both the car and the truck classes have methods named passengers() but this causes no problems and is perfectly acceptable. • If classes are related in some way, and they certainly are if they are both derived classes of a common base class, you would expect them to be doing somewhat similar things. • In this situation there is a good possibility that a method name would be repeated in both child classes.
THE TRUCK IMPLEMENTATION Example program ------> TRUCK.CPP • Examine the file named TRUCK.CPP for the implementation of the truck class. • It has nothing unusual included in it.
USING ALL THREE CLASSES Example program ------> ALLVEHIC.CPP • It uses the parent class vehicle to declare objects and also uses the two child classes to declare objects. • This was done to illustrate that all three classes can be used in a single program.
Example program ------> ALLVEHIC.CPP • All three of the header files for the classes are included in lines 3 through 5 so the program can use the components of the classes. • Notice that the implementations of the three classes are not in view here and do not need to be in view. • This allows the code to be used without access to the source code for the actual implementation of the class. However, it should be clear that the header file definition must be available.
Example program ------> ALLVEHIC.CPP • In this example program, only one object of each class is declared and used but as many as desired could be declared and used in order to accomplish the programming task at hand. • The classes were developed, debugged, and stored away previously, and the interfaces were kept very simple.
Compile and Link • The three classes and the main() program can be compiled in any order desired. • All four must be compiled prior to linking the four resulting object (or binary) files together. • Be sure you do the required steps to compile and execute this program because the effective use of C++ will require you to compile many separate files and link them together.
WHY THE #ifndef VEHICLE_H ? • When we define the derived class car, we are required to supply it with the full definition of the interface to the vehicle class since car is a derived class of vehicle and must know all about its parent. • We do that by including the vehicle class into the car class, and the car class can be compiled. The vehicle class must also be included in the header file of the truck class for the same reason.
WHY THE #ifndef VEHICLE_H ? • When the preprocessor gets to the car class, it includes the vehicle class because it is listed in the car class header file, but since the vehicle class was already included in line 3 of ALLVEHIC.CPP, it is included twice and we attempt to re-declare the class vehicle. • Of course it is the same declaration, but the system doesn't care, it simply doesn't allow re-declaration of a class.
The Main Concept • Static Array • Pre-allocation Required • Waste-full if you allocate too much • Fatal if you allocate too little • Data has to be shifted when an item is inserted or deleted at specified position • Dynamic Array • Determine the size before allocating memory • Costly reallocation, insertion, deletion • Data has to be shifted • Linked List • Truly dynamic, memory is allocated as needed
Linked Lists • To maintain a given order you don't have to store data in this order. • Each item of the list points to the next one. • You can always determine the successor, no matter where it is physically. • You can insert and delete items without shifting the whole list. • The size of the list can be increased easily by adding successors.
Pointers • A pointer variable (or just pointer) contains the location of address in memory, of a memory cell. • By using a pointer to a particular memory cell, you can locate the cell and determine its content. int *p,q; q=1234; p=q;
Pointers: dynamic memory allocation • A pointer can point at the memory area allocated at execution time. int *p; p=new int; *p=1234; delete p; int *p; p=new int[10]; *(p+2)=1234; p[1]=2222; delete [] p;
(a) Declaring pointer variables; (b) pointing to statically allocated memory; (c) assigning a value
(d) Allocating memory dynamically; (e) assigning a value; (f) copying a pointer
(g) Allocating memory dynamically and assigning a value; (h) assigning NULL to a pointer variable; (i) de-allocating memory
Programming with pointer variables and dynamically allocated memory
Programming with pointer variables and dynamically allocated memory
Programming with pointer variables and dynamically allocated memory
Pointer-based Linked Lists • A linked list contains components that are linked to one another. • Each component (a node) contains: • a data item, • a pointer to the next item.
A Node struct Node { int item; Node *next; }; • Any time you allocate memory using new, you must de-allocate it by using delete. • head points at the first element on the list. Node *p,*head; head=NULL; p=new Node; p->item=1; p->next=NULL; head=p; ... delete p;
A misconception head=new Node; head=NULL; • Memory is allocated for Node structure, head points at the allocated area. • headpoints at 'nothing' • The allocated memory is lost (a memory leak) • You shouldn't allocate memory for head, it is just a pointer.
The List Traversal Let a current pointer point to the first node in the linked list. while (the current pointer is not NULL) { Display the data portion of the current node Set the current pointer to the next pointer of the current node } Node *cur; ... for (cur=head; cur!=NULL; cur=cur->next) cout << cur->item << endl;
Deleting a Specified Node • Assumption: The linked list exists. • There are three pointers set: • head – the first element of the list, • cur – the current element of the list, • prev – the previous element of the list. • Deletion: prev->next=cur->next; cur->next=NULL; delete cur; cur=NULL;
Deleting the First Node • The previous method doesn't work for the first element, because prev has nothing to point at. • This is a special case. • When the first node is deleted, the value of head has to be changed: • head=head->next; • The memory occupied by the first element has to be de-allocated.