Inheritance. Notes Chapter 6 and AJ Chapters 7 and 8

Similar documents
Inheritance (Part 2) Notes Chapter 6

Inheritance (Part 5) Odds and ends

Interfaces. consider an interface for mathematical functions of the form

Inheritance (cont) Abstract Classes

Inheritance, cont. Notes Chapter 6 and AJ Chapters 7 and 8

INHERITANCE. Spring 2019

Inheritance. Transitivity

Inheritance. Lecture 11 COP 3252 Summer May 25, 2017

Day 4. COMP1006/1406 Summer M. Jason Hinek Carleton University

CS-202 Introduction to Object Oriented Programming

Name Return type Argument list. Then the new method is said to override the old one. So, what is the objective of subclass?

Java Classes, Inheritance, and Interfaces

Rules and syntax for inheritance. The boring stuff

Java Object Oriented Design. CSC207 Fall 2014

CMSC131. Inheritance. Object. When we talked about Object, I mentioned that all Java classes are "built" on top of that.

Java Fundamentals (II)

Abstract and final classes [Horstmann, pp ] An abstract class is kind of a cross between a class and an interface.

Polymorphism. return a.doublevalue() + b.doublevalue();

Inheritance. Inheritance allows the following two changes in derived class: 1. add new members; 2. override existing (in base class) methods.

CS5000: Foundations of Programming. Mingon Kang, PhD Computer Science, Kennesaw State University

Chapter 6: Inheritance

C12a: The Object Superclass and Selected Methods

Computer Science 210: Data Structures

More about inheritance

Super-Classes and sub-classes

Advanced Programming - JAVA Lecture 4 OOP Concepts in JAVA PART II

Aggregation and Composition. [notes Chapter 4]

Distributed Systems Recitation 1. Tamim Jabban

ITI Introduction to Computing II

COMP200 INHERITANCE. OOP using Java, from slides by Shayan Javed

Graphical Interface and Application (I3305) Semester: 1 Academic Year: 2017/2018 Dr Antoun Yaacoub

ITI Introduction to Computing II

AP CS Unit 6: Inheritance Notes

Abstract Classes and Interfaces

Today. Book-keeping. Inheritance. Subscribe to sipb-iap-java-students. Slides and code at Interfaces.

INHERITANCE & POLYMORPHISM. INTRODUCTION IB DP Computer science Standard Level ICS3U. INTRODUCTION IB DP Computer science Standard Level ICS3U

Chapter 10 Inheritance and Polymorphism. Dr. Hikmat Jaber

Inheritance. Inheritance Reserved word protected Reserved word super Overriding methods Class Hierarchies Reading for this lecture: L&L

Class, Variable, Constructor, Object, Method Questions

Object-Oriented Concepts

COMP 250 Fall inheritance Nov. 17, 2017

For this section, we will implement a class with only non-static features, that represents a rectangle

Java Magistère BFA

HAS-A Relationship. Association is a relationship where all objects have their own lifecycle and there is no owner.

Declarations and Access Control SCJP tips

CS1150 Principles of Computer Science Objects and Classes

The class Object. Lecture CS1122 Summer 2008

Inheritance and Polymorphism

Inheritance and Polymorphism

Creating an Immutable Class. Based on slides by Prof. Burton Ma

1 Shyam sir JAVA Notes

What is Inheritance?

Example: Count of Points

The Object Class. java.lang.object. Important Methods In Object. Mark Allen Weiss Copyright 2000

Chapter 10 Classes Continued. Fundamentals of Java

Chapter 11 Inheritance and Polymorphism. Motivations. Suppose you will define classes to model circles,

Instance Members and Static Members

Binghamton University. CS-140 Fall Chapter 9. Inheritance

Java Inheritance. Written by John Bell for CS 342, Spring Based on chapter 6 of Learning Java by Niemeyer & Leuck, and other sources.

Distributed Systems Recitation 1. Tamim Jabban

HAS-A Relationship. If A uses B, then it is an aggregation, stating that B exists independently from A.

Lecture Notes Chapter #9_b Inheritance & Polymorphism

Programming overview

Computer Science 2 Lecture 4 Inheritance: Trinidad Fruit Stand 02/15/2014 Revision : 1.7

Making New instances of Classes

CLASS DESIGN. Objectives MODULE 4

IST311. Advanced Issues in OOP: Inheritance and Polymorphism

PROGRAMMING LANGUAGE 2

UNIT 3 ARRAYS, RECURSION, AND COMPLEXITY CHAPTER 11 CLASSES CONTINUED

Comp 249 Programming Methodology

Inheritance CSC 123 Fall 2018 Howard Rosenthal

Object Oriented Programming is a programming method that combines: Advantage of Object Oriented Programming

Inheritance: Definition

Introduction to OOP with Java. Instructor: AbuKhleif, Mohammad Noor Sep 2017

Java and OOP. Part 3 Extending classes. OOP in Java : W. Milner 2005 : Slide 1

8. Polymorphism and Inheritance

CS 251 Intermediate Programming Inheritance

More on inheritance CSCI 136: Fundamentals of Computer Science II Keith Vertanen Copyright 2014

CISC-124. Passing Parameters. A Java method cannot change the value of any of the arguments passed to its parameters.

More About Objects. Zheng-Liang Lu Java Programming 255 / 282

24. Inheritance. Java. Fall 2009 Instructor: Dr. Masoud Yaghini

CSE1720. General Info Continuation of Chapter 9 Read Chapter 10 for next week. Second level Third level Fourth level Fifth level

Abstract Classes and Polymorphism CSC 123 Fall 2018 Howard Rosenthal

JAVA MOCK TEST JAVA MOCK TEST II

Outline. Java Models for variables Types and type checking, type safety Interpretation vs. compilation. Reasoning about code. CSCI 2600 Spring

COMP200 - Object Oriented Programming: Test One Duration - 60 minutes

22. Inheritance. Java. Summer 2008 Instructor: Dr. Masoud Yaghini

Abstract Classes. Abstract Classes a and Interfaces. Class Shape Hierarchy. Problem AND Requirements. Abstract Classes.

+ Inheritance. Sometimes we need to create new more specialized types that are similar to types we have already created.

Methods Common to all Classes

Inheritance, Polymorphism, and Interfaces

More Relationships Between Classes

The software crisis. code reuse: The practice of writing program code once and using it in many contexts.

Inheritance Systems. Merchandise. Television Camcorder Shirt Shoe Dress 9.1.1

Advanced Placement Computer Science. Inheritance and Polymorphism

COMP 250. inheritance (cont.) interfaces abstract classes

Lecture 18 CSE11 Fall 2013 Inheritance

Programming in Java, 2e Sachin Malhotra Saurabh Choudhary

Big software. code reuse: The practice of writing program code once and using it in many contexts.

Polymorphism: Inheritance Interfaces

Transcription:

Inheritance Notes Chapter 6 and AJ Chapters 7 and 8 1

Inheritance you know a lot about an object by knowing its class for example what is a Komondor? http://en.wikipedia.org/wiki/file:komondor_delvin.jpg 2

Object Dog is-a Object Dog PureBreed is-a Dog PureBreed is-a Object PureBreed Mix BloodHound Komondor... Komondor is-a PureBreed Komondor is-a Dog Komondor is-a Object 3

superclass of Dog (and all other classes) subclass of Object superclass of PureBreed Object Dog superclass == base class parent class subclass == derived class extended class child class subclass of Dog superclass of Komondor PureBreed Mix BloodHound Komondor... 4

Object Dog extends Object Dog PureBreed extends Dog PureBreed Mix BloodHound Komondor... Komondor extends PureBreed 5

Some Definitions we say that a subclass is derived from its superclass with the exception of Object, every class in Java has one and only one superclass Java only supports single inheritance a class X can be derived from a class that is derived from a class, and so on, all the way back to Object X is said to be descended from all of the classes in the inheritance chain going back to Object all of the classes X is derived from are called ancestors of X 6

Why Inheritance? a subclass inherits all of the non-private members (attributes and methods but not constructors) from its superclass if there is an existing class that provides some of the functionality you need you can derive a new class from the existing class the new class has direct access to the public and protected attributes and methods without having to redeclare or re-implement them the new class can introduce new attributes and methods the new class can re-define (override) its superclass methods 7

Is-A inheritance models the is-a relationship between classes from a Java point of view, is-a means you can use a derived class instance in place of an ancestor class instance public somemethod(dog dog) { // does something with dog // client code of somemethod Komondor shaggy = new Komondor(); somemethod( shaggy ); Mix mutt = new Mix (); somemethod( mutt ); 8

Is-A Pitfalls is-a has nothing to do with the real world is-a has everything to do with how the implementer has modelled the inheritance hierarchy the classic example: Circle is-a Ellipse? Ellipse Circle 9

Circle is-a Ellipse? if Ellipse can do something that Circle cannot, then Circle is-a Ellipse is false remember: is-a means you can substitute a derived class instance for one of its ancestor instances if Circle cannot do something that Ellipse can do then you cannot (safely) substitute a Circle instance for an Ellipse instance 10

// method in Ellipse /* * Change the width and height of the ellipse. * @param width The desired width. * @param height The desired height. * @pre. width > 0 && height > 0 */ public void setsize(double width, double height) { this.width = width; this.height = height; 11

there is no good way for Circle to support setsize (assuming that the attributes width and height are always the same for a Circle) because clients expect setsize to set both the width and height can't Circle override setsize so that it throws an exception if width!= height? no; this will surprise clients because Ellipse setsize does not throw an exception if width!= height can't Circle override setsize so that it sets width == height? no; this will surprise clients because Ellipse setsize says that the width and height can be different 12

what if there is no setsize method? if a Circle can do everything an Ellipse can do then Circle can extend Ellipse 13

Implementing Inheritance suppose you want to implement an inheritance hierarchy that represents breeds of dogs for the purpose of helping people decide what kind of dog would be appropriate for them many possible attributes: appearance, size, energy, grooming requirements, amount of exercise needed, protectiveness, compatibility with children, etc. we will assume two attributes measured on a 10 point scale size from 1 (small) to 10 (giant) energy from 1 (lazy) to 10 (high energy) 14

Dog public class Dog extends Object { private int size; private int energy; // creates an "average" dog Dog() { this(5, 5); Dog(int size, int energy) { this.setsize(size); this.setenergy(energy); 15

public int getsize() { return this.size; public int getenergy() { return this.energy; public final void setsize(int size) { this.size = size; public final void setenergy(int energy) { this.energy = energy; why final? stay tuned 16

What is a Subclass? a subclass looks like a new class that has the same API as its superclass with perhaps some additional methods and attributes inheritance does more than copy the API of the superclass the derived class contains a subobject of the parent class the superclass subobject needs to be constructed (just like a regular object) the mechanism to perform the construction of the superclass subobject is to call the superclass constructor 17

Constructors of Subclasses 1. the first line in the body of every constructor must be a call to another constructor if it is not then Java will insert a call to the superclass default constructor if the superclass default constructor does not exist or is private then a compilation error occurs 2. a call to another constructor can only occur on the first line in the body of a constructor 3. the superclass constructor must be called during construction of the derived class 18

Mix (version 1) public final class Mix extends Dog { // no declaration of size or energy; inherited from Dog private ArrayList<String> breeds; public Mix () { // call to a Dog constructor super(); this.breeds = new ArrayList<String>(); public Mix(int size, int energy) { // call to a Dog constructor super(size, energy); this.breeds = new ArrayList<String>(); 19

public Mix(int size, int energy, ArrayList<String> breeds) { // call to a Dog constructor super(size, energy); this.breeds = new ArrayList<String>(breeds); 20

Mix (version 2) public final class Mix extends Dog { // no declaration of size or energy; inherited from Dog private ArrayList<String> breeds; public Mix () { // call to a Mix constructor this(5, 5); public Mix(int size, int energy) { // call to a Mix constructor this(size, energy, new ArrayList<String>()); 21

public Mix(int size, int energy, ArrayList<String> breeds) { // call to a Dog constructor super(size, energy); this.breeds = new ArrayList<String>(breeds); 22

Dog - size : int - energy : int + setsize() + setenergy() + equals(object) : boolean + hashcode() : int + tostring() : String... Mix - breeds : ArrayList<String> + equals(object) : boolean + hashcode() : int + tostring() : String... 23

why is the constructor call to the superclass needed? because Mix is-a Dog and the Dog part of Mix needs to be constructed a derived class can only call its own constructors or the constructors of its immediate superclass Mix can call Mix constructors or Dog constructors Mix cannot call the Object constructor Object is not the immediate superclass of Mix Mix cannot call PureBreed constructors cannot call constructors across the inheritance hierarchy PureBreed cannot call Komondor constructors cannot call subclass constructors 24

Constructors & Overridable Methods if a class is intended to be extended then its constructor must not call an overridable method Java does not enforce this guideline why? recall that a derived class object has inside of it an object of the superclass the superclass object is always constructed first, then the subclass constructor completes construction of the subclass object the superclass constructor will call the overridden version of the method (the subclass version) even though the subclass object has not yet been constructed 25

Superclass Ctor & Overridable Method public class SuperDuper { public SuperDuper() { // call to an over-ridable method; bad this.overrideme(); public void overrideme() { System.out.println("SuperDuper overrideme"); 26

Subclass Overrides Method public class SubbyDubby extends SuperDuper { private final Date date; public SubbyDubby() { super(); this.date = new Date(); @Override public void overrideme() { System.out.print("SubbyDubby overrideme : "); System.out.println( this.date ); public static void main(string[] args) { SubbyDubby sub = new SubbyDubby(); sub.overrideme(); 27

the programmer's intent was probably to have the program print: SuperDuper overrideme SubbyDubby overrideme : <the date> or, if the call to the overridden method was intentional SubbyDubby overrideme : <the date> SubbyDubby overrideme : <the date> but the program prints: SubbyDubby overrideme : null SubbyDubby overrideme : <the date> final attribute in two different states! 28

What's Going On? 1. new SubbyDubby() calls the SubbyDubby constructor 2. the SubbyDubby constructor calls the SuperDuper constructor 3. the SuperDuper constructor calls the method overrideme which is overridden by SubbyDubby 4. the SubbyDubby version of overrideme prints the SubbyDubby date attribute which has not yet been assigned to by the SubbyDubby constructor (so date is null) 5. the SubbyDubby constructor assigns date 6. SubbyDubby overrideme is called by the client 29

remember to make sure that your base class constructors only call final methods or private methods if a base class constructor calls an overridden method, the method will run in an unconstructed derived class 30

Other Methods methods in a subclass will often need or want to call methods in the immediate superclass a new method in the subclass can call any public or protected method in the superclass without using any special syntax a subclass can override a public or protected method in the superclass by declaring a method that has the same signature as the one in the superclass a subclass method that overrides a superclass method can call the overridden superclass method using the super keyword 31

Dog equals we will assume that two Dogs are equal if their size and energy are the same @Override public boolean equals(object obj) { boolean eq = false; if(obj!= null && this.getclass() == obj.getclass()) { Dog other = (Dog) obj; eq = this.getsize() == other.getsize() && this.getenergy() == other.getenergy(); return eq; 32

Mix equals (version 1) two Mix instances are equal if their Dog subobjects are equal and they have the same breeds @Override public boolean equals(object obj) { // the hard way 33 boolean eq = false; if(obj!= null && this.getclass() == obj.getclass()) { Mix other = (Mix) obj; subclass can call eq = this.getsize() == other.getsize() && public method of this.getenergy() == other.getenergy() && the superclass this.breeds.size() == other.breeds.size() && return eq; this.breeds.containsall(other.breeds);

Mix equals (version 2) two Mix instances are equal if their Dog subobjects are equal and they have the same breeds Dog equals already tests if two Dog instances are equal Mix equals can call Dog equals to test if the Dog subobjects are equal, and then test if the breeds are equal also notice that Dog equals already checks that the Object argument is not null and that the classes are the same Mix equals does not have to do these checks again 34

@Override public boolean equals(object obj) { boolean eq = false; if(super.equals(obj)) { // the Dog subobjects are equal Mix other = (Mix) obj; eq = this.breeds.size() == other.breeds.size() && this.breeds.containsall(other.breeds); return eq; subclass method that overrides a superclass method can call the overridden superclass method 35

Dog tostring @Override public String tostring() { String s = "size " + this.getsize() + "energy " + this.getenergy(); return s; 36

Mix tostring @Override public String tostring() { StringBuffer b = new StringBuffer(); b.append(super.tostring()); for(string s : this.breeds) b.append(" " + s); b.append(" mix"); return b.tostring(); 37

Dog hashcode // similar to code generated by Eclipse @Override public int hashcode() { final int prime = 31; int result = 1; result = prime * result + this.getenergy(); result = prime * result + this.getsize(); return result; 38

Mix hashcode // similar to code generated by Eclipse @Override public int hashcode() { final int prime = 31; int result = super.hashcode(); result = prime * result + this.breeds.hashcode(); return result; 39

Mix Memory Diagram inherited from superclass private in superclass not accessible by name to Mix 500 Mix object size 5 energy 5 breeds 1750 40

Mix UML Diagram Dog Mix 1 breeds ArrayList<String> 41