6-1 © 2004, D.A. Watt, University of Glasgow 6 Data Abstraction  Packages and encapsulation.  Abstract types.  Classes, subclasses, and inheritance.

Slides:



Advertisements
Similar presentations
More on Classes Inheritance and Polymorphism
Advertisements

Overriding CMPS Overriding Recall, a method in a child class overrides a method in the parent class, if it has the same name and type signature.
Object Oriented Programming
SUMMARY: abstract classes and interfaces 1 Make a class abstract so instances of it cannot be created. Make a method abstract so it must be overridden.
Module 8 “Polymorphism and Inheritance”. Outline Understanding Inheritance Inheritance Diagrams Constructors in Derived Classes Type Compatibility Polymorphism.
Inheritance Lakshmish Ramaswamy. Example A Rectangle class with area method A Circle class with area method Array containing references to circles & rectangles.
Abstract Data Types Data abstraction, or abstract data types, is a programming methodology where one defines not only the data structure to be used, but.
CS 106 Introduction to Computer Science I 04 / 11 / 2008 Instructor: Michael Eckmann.
Inheritance Inheritance Reserved word protected Reserved word super
Objectives Introduction to Inheritance and Composition (Subclasses and SuperClasses) Overriding (and extending), and inheriting methods and constructors.
CS 106 Introduction to Computer Science I 11 / 26 / 2007 Instructor: Michael Eckmann.
Inheritance. Extending Classes It’s possible to create a class by using another as a starting point  i.e. Start with the original class then add methods,
1 Lecture 3 Inheritance. 2 A class that is inherited is called superclass The class that inherits is called subclass A subclass is a specialized version.
Inheritance and Class Hierarchies Chapter 3. Chapter 3: Inheritance and Class Hierarchies2 Chapter Objectives To understand inheritance and how it facilitates.
Fall 2007CS 2251 Inheritance and Class Hierarchies Chapter 3.
CS 106 Introduction to Computer Science I 11 / 20 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 04 / 16 / 2010 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 11 / 15 / 2006 Instructor: Michael Eckmann.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. 4 th Ed Chapter N - 1 Chapter 13 Polymorphism is-a relationships Interfaces.
Chapter 11: Inheritance and Polymorphism Java Programming: Program Design Including Data Structures Program Design Including Data Structures.
(c) University of Washington03-1 CSC 143 Java Inheritance Reading: Ch. 10.
Chapter 6 Class Inheritance F Superclasses and Subclasses F Keywords: super F Overriding methods F The Object Class F Modifiers: protected, final and abstract.
C++ Object Oriented 1. Class and Object The main purpose of C++ programming is to add object orientation to the C programming language and classes are.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Taken from slides of Starting Out with C++ Early Objects Seventh Edition.
“is a”  Define a new class DerivedClass which extends BaseClass class BaseClass { // class contents } class DerivedClass : BaseClass { // class.
Lecture 3 Casting Abstract Classes and Methods Interfaces.
Introduction to Object Oriented Programming. Object Oriented Programming Technique used to develop programs revolving around the real world entities In.
CSC 142 O 1 CSC 142 Java More About Inheritance & Interfaces [Reading: chapter 13]
1 Chapter 10: Data Abstraction and Object Orientation Aaron Bloomfield CS 415 Fall 2005.
1 Java Inheritance. 2 Inheritance On the surface, inheritance is a code re-use issue. –we can extend code that is already written in a manageable manner.
Programming in Java Unit 2. Class and variable declaration A class is best thought of as a template from which objects are created. You can create many.
Features of Object Oriented Programming Lec.4. ABSTRACTION AND ENCAPSULATION Computer programs can be very complex, perhaps the most complicated artifact.
1 COSC3557: Object-Oriented Programming Haibin Zhu, Ph. D. Associate Professor of CS, Nipissing University.
CS200 Algorithms and Data StructuresColorado State University Part 4. Advanced Java Topics Instructor: Sangmi Pallickara
CSC 205 Java Programming II Polymorphism. Topics Polymorphism The principle of substitution Dynamic binding Object type casting Abstract class The canonical.
Generic abstraction  Genericity  Generic classes  Generic procedures Programming Languages 3 © 2012 David A Watt, University of Glasgow.
Chris Kiekintveld CS 2401 (Fall 2010) Elementary Data Structures and Algorithms Inheritance and Polymorphism.
Inheritance - Polymorphism ITI 1121 Nour El Kadri.
More on Hierarchies 1. When an object of a subclass is instantiated, is memory allocated for only the data members of the subclass or also for the members.
CS 106 Introduction to Computer Science I 04 / 23 / 2010 Instructor: Michael Eckmann.
Chapter 3 Inheritance and Polymorphism Goals: 1.Superclasses and subclasses 2.Inheritance Hierarchy 3.Polymorphism 4.Type Compatibility 5.Abstract Classes.
Inheritance. Inheritance - Introduction Idea behind is to create new classes that are built on existing classes – you reuse the methods and fields and.
Chapter 3 Introduction to Classes and Objects Definitions Examples.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 9 Inheritance and.
Chapter 7: Class Inheritance F Superclasses and Subclasses F Keywords: super and this F Overriding methods F The Object Class F Modifiers: protected, final.
1 COSC2007 Data Structures II Chapter 9 Class Relationships.
Inheritance CSI 1101 Nour El Kadri. OOP  We have seen that object-oriented programming (OOP) helps organizing and maintaining large software systems.
Chapter 8 Class Inheritance and Interfaces F Superclasses and Subclasses  Keywords: super F Overriding methods  The Object Class  Modifiers: protected,
Application development with Java Lecture 21. Inheritance Subclasses Overriding Object class.
1 Inheritance Reserved word protected Reserved word super Overriding methods Class Hierarchies Reading for this lecture: L&L 9.1 – 9.4.
Inheritance and Class Hierarchies Chapter 3. Chapter 3: Inheritance and Class Hierarchies2 Chapter Objectives To understand inheritance and how it facilitates.
Inheritance and Class Hierarchies Chapter 3. Chapter Objectives  To understand inheritance and how it facilitates code reuse  To understand how Java.
Chapter 11: Advanced Inheritance Concepts. Objectives Create and use abstract classes Use dynamic method binding Create arrays of subclass objects Use.
Inheritance and Polymorphism
POLYMORPHISM Chapter 6. Chapter Polymorphism  Polymorphism concept  Abstract classes and methods  Method overriding  Concrete sub classes and.
 Description of Inheritance  Base Class Object  Subclass, Subtype, and Substitutability  Forms of Inheritance  Modifiers and Inheritance  The Benefits.
BY:- TOPS Technologies
Polymorphism and access control. RHS – SOC 2 What is polymorphism? In general: the ability of some concept to take on different forms In Java: the ability.
Inheritance Modern object-oriented (OO) programming languages provide 3 capabilities: encapsulation inheritance polymorphism which can improve the design,
Modern Programming Tools And Techniques-I
Lecture 12 Inheritance.
Inheritance and Polymorphism
12 Data abstraction Packages and encapsulation
Java Programming Language
Polymorphism and access control
More About Inheritance & Interfaces
Chapter 11 Inheritance and Encapsulation and Polymorphism
C++ Object Oriented 1.
Programming in C# CHAPTER 5 & 6
Presentation transcript:

6-1 © 2004, D.A. Watt, University of Glasgow 6 Data Abstraction  Packages and encapsulation.  Abstract types.  Classes, subclasses, and inheritance.  Implementation notes.

6-2 Packages  A package is a named group of components declared for a common purpose.  These components may be types, constants, variables, procedures, etc.

6-3 Example: Ada simple package  Package: package Earth is type Continent is ( Africa, Asia, Australia, Europe, N_America, S_America); radius: constant Float := 6.4e3; -- km population: array (Continent) of Natural; end Earth;  Bindings produced by this package: { Continent  the type Continent = {Africa, Asia, …}, radius  the real number 6.4  10 3, population  an array variable of type Continent  Natural }

6-4 Encapsulation (1)  Encapsulation means making some components of a program unit (package, abstract type, or class) private.  Several possible levels of privacy: A component is private if it is visible only inside the program unit. A component is protected if it is visible only inside the program unit and certain closely-related program units. A component is public if it is visible to application code outside the program unit.  A program unit’s API (application program interface) consists of its public bindings only.

6-5 Encapsulation (2)  An Ada package consists of two parts: Public components are declared in the package specification. Private components are declared in the package body (or in the private part of the package specification).

6-6 Example: Ada package with encapsulation (1)  Package specification: package Trig is function sin (x: Float) return Float; function cos (x: Float) return Float; end Trig; public function

6-7 Example: Ada package with encapsulation (2)  Package body: package Trig is twice_pi: constant Float := ; function norm (x: Float) return Float is … -- compute x modulo twice_pi function sin (x: Float) return Float is … -- compute the sine of norm(x) function cos (x: Float) return Float is … -- compute the cosine of norm(x) end Trig; private constant private function

6-8 Example: Ada package with encapsulation (3)  This package’s API: { sin  function procedure that approximates the sine function, cos  function procedure that approximates the cosine function }

6-9 Example: Ada encapsulated variables (1)  Package specification: package The_Dictionary is procedure clear; -- Make the dictionary empty. procedure add (w: in Word); -- Add w to the dictionary if it is not already there. function contains (w: Word) return Boolean; -- Return true if and only if w is in the dictionary. end The_Dictionary; public function public procedure

6-10 Example: Ada encapsulated variables (2)  Package body: package body The_Dictionary is cap: constant := 1000; size: Integer := 0; words: array (1.. cap) of Word; procedure clear is … procedure add (wd: in Word) is … function contains (wd: Word) return Boolean is … end The_Dictionary; private constant private variables access size and words

6-11 Example: Ada encapsulated variables (3)  This package’s API: { clear  proper procedure that makes the dictionary empty, add  proper procedure that adds a word to the dictionary, contains  function procedure that tests whether a word is in the dictionary }  Possible application code: use The_Dictionary; … if not contains(current_word) then … add(current_word); end if; … size := 0; illegal!

6-12 Abstract types  An abstract type has a private representation but is equipped with public operations. (The operations may be constants and/or procedures.)  Some PLs support abstract types directly.  Ada supports abstract types by means of packages. The abstract type is declared in the package specification in two stages: The type declaration is public, but doesn’t define the representation. The private part contains a full type definition.

6-13 Example: Ada abstract type (1)  Package specification: package Dictionaries is type Dictionary is limited private; -- A Dictionary value represents a set of words. procedure clear (d: in out Dictionary); -- Make d empty. procedure add (d: in out Dictionary; w: in Word); -- Add w to d if it is not already there. function contains (d: Dictionary; w: Word) return Boolean; -- Return true if and only if w is in d. private type public function public procedure

6-14 Example: Ada abstract type (2)  Package specification (continued): private cap: constant Integer := 1000; type Dictionary is record size: Integer; words: array (1.. cap) of Word; end record; end Dictionaries; private constant full type definition

6-15 Example: Ada abstract type (3)  Package body: package body Dictionaries is procedure clear (d: in out Dictionary) is … procedure add (d: in out Dictionary; w: in Word) is … function contains (d: Dictionary; w: Word)return Boolean is … end Dictionaries;

6-16 Example: Ada abstract type (4)  This package’s API: { Dictionary  an abstract type representing a set of words, clear  proper procedure that makes a dictionary empty, add  proper procedure that adds a word to a dictionary, contains  function procedure that tests whether a word is in a dictionary }

6-17 Example: Ada abstract type (5)  Possible application code: use Dictionaries; main_dict, user_dict: Dictionary; … if not contains(mainDict, current_word) and not contains(userDict, current_word) then … add(userDict, current_word); end if; … user_dict.size := 0; illegal

6-18 Classes (1)  An object is a tuple of variable components (instance variables), equipped with a group of operations that access these variables.  A class is a set of similar objects. All objects of a given class have similar instance variables, and are equipped with the same operations.  A constructor is an operation that creates and initializes a new object of the class.  A method is an operation that inspects and/or updates an existing object of the class.

6-19 Classes (2)  A Java class declaration: declares all instance variables defines all constructors defines all methods specifies whether each of these is private, protected, or public.  A Java method call has the form “O. M ( … ) ”: The expression O determines the target object. M is the name of the method to be called. The call executes the method body, with this denoting the target object.

6-20 Example: Java class (1)  Class declaration: class Dictionary { private int size; private String[] words; public Dictionary (int capacity) { … } public void add (String w) { if (! this.contains(w)) this.words[this.size++] = w; } public boolean contains (String w) { … } } public method public constructor private variables

6-21 Example: Java class (2)  Possible application code: Dictionary mainDict = new Dictionary(10000); Dictionary userDict = new Dictionary(1000); … if (! mainDict.contains(currentWord) && ! userDict.contains(currentWord)) { … userDict.add(currentWord); } … userDict.size = 0; target object illegal!

6-22 Subclasses  Recall: A class C is a set of similar objects. All objects of class C have similar instance variables, and are equipped with the same operations.  A subclass of C, S, is a set of objects that are similar to one another but richer than the objects of class C: An object of class S has all the instance variables of an object of class C, but may have extra instance variables. Likewise, an object of class S is equipped with all the methods of class C, but may be equipped with extra methods.  If S is a subclass of C, we say that C is a superclass of S.

6-23 Inheritance  A subclass is said to inherit its superclass’s instance variables and methods.  Alternatively, a subclass may override some of its superclass’s methods, by providing more specialized versions of these methods.

6-24 Example: Java class and subclass (1)  Class declaration: class Point { protected double x, y; public Point () { x = 0.0; y = 0.0; } public double distance () { return Math.sqrt(x*x + y*y); } public final void move (double dx, double dy) { x += dx; y += dy; } public void draw () { … } // draw this point on the screen } This method may not be overridden. method (1) method (2) method (3)

6-25 Example: Java class and subclasses (2)  Subclass declaration: class Circle extends Point { private double r; public Circle (double radius) { x = 0.0; y = 0.0; r = radius; } public void draw () { … } // draw this circle on the screen public double diameter () { return 2.0*r; } } method (4) method (5)

6-26 Example: Java class and subclass (3)  Possible application code: Point p = new Point(); Circle c = new Circle(10.0); p.move(12.0, 5.0); c.move(3.0, 4.0); … p.distance() … … c.distance() … … c.diameter() … p.draw() ; c.draw() ; p = c; p.draw(); c is centred at (0, 0) now p is at (12, 5) now c is centred at (3, 4) yields 13 yields 5 draws a point at (12, 5) draws a circle centred at (3, 4) yields 10 p is at (0, 0) ditto! (dynamic dispatch)

6-27 Example: Java class and subclasses (4)  Another subclass declaration: class Rectangle extends Point { private double w, h; public Rectangle ( … ) { … } public void draw () { … } // draw this rectangle on the screen public double width () { return w; } public double height () { return h; } } method (6) method (7) method (8)

6-28 Overriding  Each method of a class C is inherited by the subclass S, unless it is overridden by S.  The overriding method in class S has the same name and type as the original method in class C.  Some OO PLs allow programmers to specify whether a method may be overridden or not: In C++, a method specified as virtual may be overridden. In Java, a method specified as final may not be overridden.

6-29 Dynamic dispatch  If methods are overridden, and if the PL allows a variable of a particular class to refer to an object of a subclass, then method calls entail dynamic dispatch.  Consider the Java method call “O. M ( E 1, …, E n ) ”: The compiler infers the type of O, say class C. The compiler checks that class C is equipped with a method named M, of the appropriate type. Nevertheless, it might turn out (at run-time) that the target object is actually of class S, a subclass of C. If method M is overridden by any subclass of C, a run-time tag test is needed to determine the actual class of the target object, and hence which of the methods named M is to be called.

6-30 Single inheritance  Single inheritance allows each class to have at most one superclass.  Single inheritance gives rise to a hierarchy of classes.  Single inheritance is supported by most OO PLs, including Java and Ada95.

6-31 Example: Java single inheritance  Declared classes: Date (subclass of Object ) Point (subclass of Object ) Circle, Rectangle (both subclasses of Point ).  Hierarchy of classes: clone equals … Object … Date y, m, d draw width height Rectangle w, h draw diameter Circle r distance move draw Point x, y

6-32 Multiple inheritance  Multiple inheritance allows each class to have any number of superclasses.  Multiple inheritance gives rise to both conceptual and implementation problems.  Multiple inheritance is supported by C++.

6-33 Example: multiple inheritance (1)  Declared classes: Animal Mammal, Flier, Bird (all subclasses of Animal ) Cat (subclass of Mammal ) Bat (subclass of Mammal and Flier ) etc.  Class relationships: … Mammal gestation … Flier wing-span … Bird egg-size … Cat … … Bat sonar … Animal weight speed … Eagle … … Penguin …

6-34 Example: multiple inheritance (2)  Suppose: the Animal class defines a method named move the Mammal and Flier classes both override that method.  Then which method does the Bat class inherit? E.g.: Bat b; b.move( … ); Which method does this call?  Possible answers: Call the Mammal method (since Mammal is the first-named superclass of Bat ). Force the programmer to choose, either in the Bat class declaration or in the method call. Prohibit this method call (since it is ambiguous).

6-35 Representation of objects (1)  Each object of a given class is represented by a tag field juxtaposed with the object’s instance variables. The tag field indicates the object’s class.  Tag fields are needed whenever objects of different classes can be used interchangeably, in particular to implement dynamic dispatch.

6-36 Representation of objects (2)  Implementation of access to an instance variable: Let o be an object of class C. Each instance variable o. v has a fixed offset (determined by the compiler) relative to the base address of o.  Assuming single inheritance, this implementation works even if o is replaced by an object of a subclass of C (since inherited instance variables are located at the same offset in both C and its subclasses).  But multiple inheritance makes it more difficult to represent objects such that instance variables can be accessed efficiently.

6-37 Example: representation of Java objects (1)  Representation of Point, Circle, Rectangle objects (simplified): tag x y Point x 0.0 y r 5.0 tag Circle x y w h tag Rect.  The class tags are actually pointers to “class objects” (see later).

6-38 Implementation of method calls (1)  In a method call, the target object’s address is passed to the method, along with the ordinary arguments. (Thus the method can inspect/update the target object.)  If the named method is never overridden, the method call is implemented like an ordinary procedure call. Otherwise dynamic dispatch must be implemented, as follows.  For each class C in the program, create a class object containing the addresses of C’s methods.  Make each object of class C contain (in its tag field) a pointer to C’s class object.

6-39 Implementation of method calls (2)  Implement the method call “O. M ( … ) ” as follows: 1.Determine the target object from O. 2.Follow the pointer from the target object’s tag field to the corresponding class object. 3.Select the method named M in the class object. 4.Call that method, passing the target object’s address along with the ordinary arguments.  The method named M can be selected efficiently in step 3, since the compiler can determine its offset relative to the base of the class object, assuming single inheritance.  Multiple inheritance makes it more difficult to implement dynamic dispatch efficiently.

6-40 Example: representation of Java objects (2)  Representation of Point, Circle, Rectangle objects: tag x y x 0.0 y r 5.0 tag x y w h tag method (1) method (2) method (6) Rectangle class object distance move draw method (7) width method (8) height method (1) method (2) method (4) Circle class object move draw method (5) diameter distance method (1) method (2) method (3) move draw Point class object distance