Further abstraction techniques Abstract classes and interfaces 1.0.

Slides:



Advertisements
Similar presentations
Chapter 13 Abstraction and inheritance. This chapter discusses n Implementing abstraction. u extension u inheritance n Polymorphism/dynamic binding. n.
Advertisements

Interfaces.
Further abstraction techniques Abstract classes and interfaces 5.0.
Inheritance Inheritance Reserved word protected Reserved word super
1 Inheritance Reserved word protected Reserved word super Overriding methods Class Hierarchies Reading for this lecture: L&L 8.1 – 8.5.
OOP in Java Nelson Padua-Perez Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
1 Chapter 6 Inheritance, Interfaces, and Abstract Classes.
Aalborg Media Lab 23-Jun-15 Inheritance Lecture 10 Chapter 8.
CS 2511 Fall  Abstraction Abstract class Interfaces  Encapsulation Access Specifiers Data Hiding  Inheritance  Polymorphism.
Chapter 10 Classes Continued
Polymorphism. Lecture Objectives To understand the concept of polymorphism To understand the concept of static or early binding To understand the concept.
Further abstraction techniques Abstract classes and interfaces 3.0.
Abstract Classes and Interfaces
OOP in Java Fawzi Emad Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
CC1007NI: Further Programming Week Dhruba Sen Module Leader (Islington College)
CC1007NI: Further Programming Week 3 Dhruba Sen Module Leader (Islington College)
COP 3003 Object-Oriented Programming - Polymorphism Dr. Janusz Zalewski, Fall 2013 Prepared by Dr Dahai Guo.
CSE 331 Software Design & Implementation Hal Perkins Autumn 2012 Java Classes, Interfaces, and Types 1.
Chapter 6 Class Inheritance F Superclasses and Subclasses F Keywords: super F Overriding methods F The Object Class F Modifiers: protected, final and abstract.
REFACTORING Lecture 4. Definition Refactoring is a process of changing the internal structure of the program, not affecting its external behavior and.
Lecture 3 Casting Abstract Classes and Methods Interfaces.
CISC6795: Spring Object-Oriented Programming: Polymorphism.
OOP (Java): Abstract/ OOP Objectives – –use a foxes-and-rabbits simulation to introduce abstract classes, interfaces, and multiple.
(C) 2010 Pearson Education, Inc. All rights reserved. Java™ How to Program, 8/e.
Introduction to Object Oriented Programming. Object Oriented Programming Technique used to develop programs revolving around the real world entities In.
Basic Object- Oriented Concepts Presented By: George Pefanis 21-Sep-15.
APCS Java AB 2004 Review of CS1 and CS2 Review for AP test #1 Sources: 2003 Workshop notes from Chris Nevison (Colgate University) AP Study Guide to go.
Chapter 2 Introducing Interfaces Summary prepared by Kirk Scott.
Inheritance in the Java programming language J. W. Rider.
Inheritance - Polymorphism ITI 1121 Nour El Kadri.
Chapter 3 Inheritance and Polymorphism Goals: 1.Superclasses and subclasses 2.Inheritance Hierarchy 3.Polymorphism 4.Type Compatibility 5.Abstract Classes.
Inheritance (Part 5) Odds and ends 1. Static Methods and Inheritance  there is a significant difference between calling a static method and calling a.
Abstract Classes and Interfaces 5-Dec-15. Abstract methods You can declare an object without defining it: Person p; Similarly, you can declare a method.
Inheritance. Inheritance - Introduction Idea behind is to create new classes that are built on existing classes – you reuse the methods and fields and.
Further abstraction techniques
Final Review. From ArrayLists to Arrays The ArrayList : used to organize a list of objects –It is a class in the Java API –the ArrayList class uses an.
1 Inheritance Reserved word protected Reserved word super Overriding methods Class Hierarchies Reading for this lecture: L&L 9.1 – 9.4.
Interfaces F What is an Interface? F Creating an Interface F Implementing an Interface F What is Marker Interface?
Abstract Classes and Interfaces Week 17.  Computer simulations  Abstract methods  Abstract classes  Interfaces  Multiple inheritance Abstract Classes.
CS2 Module 26 Category: OO Concepts Topic: Interfaces Objectives –Interfaces.
Access Specifier. Anything declared public can be accessed from anywhere. Anything declared private cannot be seen outside of its class. When a member.
Quick Review of OOP Constructs Classes:  Data types for structured data and behavior  fields and methods Objects:  Variables whose data type is a class.
(c) University of Washington06-1 CSC 143 Java Inheritance Tidbits.
// Java2101.java This program tests the features of the class. public class Java2101 { public static void main (String args[]) { System.out.println("\nJAVA2101.JAVA\n");
1 COS 260 DAY 21 Tony Gauvin. 2 Agenda Questions? 8 th Mini Quiz corrected –Good results 9 Th Mini Quiz Today –40 min covering Chap 9 Assignment 5 Due.
1 Chapter 8 Class Inheritance and Interfaces F Superclasses and Subclasses  Keywords: super F Overriding methods  The Object Class  Modifiers: protected,
Terms and Rules II Professor Evan Korth New York University (All rights reserved)
Author: DoanNX Time: 45’.  OOP concepts  OOP in Java.
POLYMORPHISM Chapter 6. Chapter Polymorphism  Polymorphism concept  Abstract classes and methods  Method overriding  Concrete sub classes and.
1 COS 260 DAY 22 Tony Gauvin. 2 Agenda Questions? 9 th Mini Quiz corrected –Good results Assignment 5 Not corrected yet Assignment 6 Posted (one more)
Further Abstraction Techniques Chapter 10. Abstract Classes There are times when you do not want someone to be able to make an object of your class. For.
COP INTERMEDIATE JAVA Inheritance, Polymorphism, Interfaces.
Chapter 9: Continuing Classes By Matt Hirsch. Table Of Contents 1.Static Fields and Methods 2.Inheritance I. Recycle Code with Inheritance II. Overriding.
Further abstraction techniques Abstract classes and interfaces 6.0.
Notices Assn 2 is due tomorrow, 7pm. Moodle quiz next week – written in the lab as before. Everything up to and including today’s lecture: Big Topics are.
11 Further abstraction techniques
Modern Programming Tools And Techniques-I
Web Design & Development Lecture 9
The Movement To Objects
Inheritance and Polymorphism
Java Programming Language
Abstract Class As per dictionary, abstraction is the quality of dealing with ideas rather than events. For example, when you consider the case of ,
Advanced Java Programming
COS 260 DAY 19 Tony Gauvin.
Java Inheritance.
COS 260 DAY 23 Tony Gauvin.
Chapter 14 Abstract Classes and Interfaces
COS 260 DAY 23 Tony Gauvin.
Further abstraction techniques
Presentation transcript:

Further abstraction techniques Abstract classes and interfaces 1.0

09/12/2004Lecture 9: Abstraction Techniques2 Main concepts to be covered Abstract classes Interfaces Multiple inheritance

09/12/2004Lecture 9: Abstraction Techniques3 Simulations Programs regularly used to simulate real-world activities. –city traffic –the weather –nuclear processes –stock market fluctuations –environmental changes –LAN networks –animal behavior

09/12/2004Lecture 9: Abstraction Techniques4 Simulations They are often only partial simulations. They often involve simplifications. –Greater detail has the potential to provide greater accuracy. –Greater detail typically requires more resources. Processing power. Simulation time.

09/12/2004Lecture 9: Abstraction Techniques5 Benefits of simulations Support useful prediction. –The weather. Allow experimentation. –Safer, cheaper, quicker. Example: –‘How will the wildlife be affected if we cut a highway through the middle of this national park?’

09/12/2004Lecture 9: Abstraction Techniques6 Predator-prey simulations There is often a delicate balance between species. –A lot of prey means a lot of food. –A lot of food encourages higher predator numbers. –More predators eat more prey. –Less prey means less food. –Less food means...

09/12/2004Lecture 9: Abstraction Techniques7 The foxes-and-rabbits project

09/12/2004Lecture 9: Abstraction Techniques8 Main classes of interest Fox –Simple model of a type of predator. Rabbit –Simple model of a type of prey. Simulator –Manages the overall simulation task. –Holds a collection of foxes and rabbits.

09/12/2004Lecture 9: Abstraction Techniques9 The remaining classes Field –Represents a 2D field. Location –Represents a 2D position. SimulatorView, FieldStats, Counter –Maintain statistics and present a view of the field.

09/12/2004Lecture 9: Abstraction Techniques10 Example of the visualization

09/12/2004Lecture 9: Abstraction Techniques11 A Rabbit’s state // Characteristics shared by all rabbits (static fields). // The age at which a rabbit can start to breed. private static final int BREEDING_AGE = 5; // The age to which a rabbit can live. private static final int MAX_AGE = 50; // The likelihood of a rabbit breeding. private static final double BREEDING_PROBABILITY = 0.15; // The maximum number of births. private static final int MAX_LITTER_SIZE = 5; // A shared random number generator to control breeding. private static final Random rand = new Random();

09/12/2004Lecture 9: Abstraction Techniques12 A Rabbit’s state // Individual characteristics (instance fields). // The rabbit's age. private int age; // Whether the rabbit is alive or not. private boolean alive; // The rabbit's position private Location location;

09/12/2004Lecture 9: Abstraction Techniques13 A Rabbit’s behavior Managed from the run method. Age incremented at each simulation ‘step’. –A rabbit could die at this point. Rabbits that are old enough might breed at each step. –New rabbits could be born at this point.

09/12/2004Lecture 9: Abstraction Techniques14 A Rabbit’s behavior public Rabbit(boolean randomAge){…} public void run(Field updatedField, List newRabbits) { incrementAge(); if(alive) { int births = breed(); for(int b = 0; b < births; b++) { Rabbit newRabbit = new Rabbit(false); newRabbits.add(newRabbit); Location loc = updatedField.randomAdjacentLocation(location); newRabbit.setLocation(loc); updatedField.place(newRabbit, loc); }

09/12/2004Lecture 9: Abstraction Techniques15 A Rabbit’s behavior Location newLocation = updatedField.freeAdjacentLocation(location); // Only transfer to the updated field if //there was a free location if(newLocation != null) { setLocation(newLocation); updatedField.place(this, newLocation); } else { // can neither move nor stay – //overcrowding - all locations taken alive = false; }}}

09/12/2004Lecture 9: Abstraction Techniques16 A Rabbit’s behavior private void incrementAge() { age++; if(age > MAX_AGE) { alive = false; } private int breed() { int births = 0; if(canBreed() && rand.nextDouble() <= BREEDING_PROBABILITY) { births = rand.nextInt(MAX_LITTER_SIZE) + 1; } return births; }

09/12/2004Lecture 9: Abstraction Techniques17 Rabbit simplifications Rabbits do not have different genders. –In effect, all are female. The same rabbit could breed at every step. All rabbits die at the same age.

09/12/2004Lecture 9: Abstraction Techniques18 A Fox’s state public class Fox { Static fields omitted // The fox's age. private int age; // Whether the fox is alive or not. private boolean alive; // The fox's position private Location location; // The fox's food level, which is increased // by eating rabbits. private int foodLevel; Methods omitted. }

09/12/2004Lecture 9: Abstraction Techniques19 A Fox’s behavior Managed from the hunt method. Foxes also age and breed. They become hungry. They hunt for food in adjacent locations.

09/12/2004Lecture 9: Abstraction Techniques20 A Fox’s behavior public void hunt(Field currentField, Field updatedField, List newFoxes) { incrementAge(); incrementHunger(); if(isAlive()) { // New foxes are born into adjacent locations. int births = breed(); for(int b = 0; b < births; b++) { Fox newFox = new Fox(false); newFoxes.add(newFox); Location loc = updatedField.randomAdjacentLocation(location); newFox.setLocation(loc); updatedField.place(newFox, loc); }

09/12/2004Lecture 9: Abstraction Techniques21 A Fox’s behavior // Move towards the source of food if found. Location newLocation = findFood(currentField, location); if(newLocation == null) {// no food found –move randomly newLocation = updatedField.freeAdjacentLocation(location); } if(newLocation != null) { setLocation(newLocation); updatedField.place(this, newLocation); } else { // can neither move nor stay - overcrowding – all // locations taken alive = false; }}}

09/12/2004Lecture 9: Abstraction Techniques22 A Fox’s behavior private Location findFood(Field field, Location location) { Iterator adjacentLocations = field.adjacentLocations(location); while(adjacentLocations.hasNext()) { Location where = (Location) adjacentLocations.next(); Object animal = field.getObjectAt(where); if(animal instanceof Rabbit) { Rabbit rabbit = (Rabbit) animal; if(rabbit.isAlive()) { rabbit.setEaten(); foodLevel = RABBIT_FOOD_VALUE; return where; }}} return null; }

09/12/2004Lecture 9: Abstraction Techniques23 Configuration of foxes Similar simplifications to rabbits. Hunting and eating could be modeled in many different ways. –Should food level be additive? –Is a hungry fox more or less likely to hunt? Are simplifications ever acceptable?

09/12/2004Lecture 9: Abstraction Techniques24 The Simulator class Three key components: –Setup in the constructor. –The populate method. Each animal is given a random starting age. –The simulateOneStep method. Iterates over the population. Two Field objects are used: field and updatedField.

09/12/2004Lecture 9: Abstraction Techniques25 The update step public class Simulator { … public void simulateOneStep() { step++; newAnimals.clear(); // let all animals act for(Iterator iter = animals.iterator(); iter.hasNext(); ) { Object animal = iter.next();

09/12/2004Lecture 9: Abstraction Techniques26 The update step if(animal instanceof Rabbit) { Rabbit rabbit = (Rabbit)animal; if(rabbit.isAlive()) { rabbit.run(updatedField, newAnimals); } else { iter.remove(); } else if(animal instanceof Fox) { Fox fox = (Fox)animal; if(fox.isAlive()) { fox.hunt(field, updatedField, newAnimals); } else { iter.remove(); }

09/12/2004Lecture 9: Abstraction Techniques27 Instanceof Checking an object’s dynamic type –obj instanceof Myclass General not considered good practice Make code to depend on the exact type of objects. The usage of instanceof is an indicator of refactoring

09/12/2004Lecture 9: Abstraction Techniques28 Room for improvement Fox and Rabbit have strong similarities but do not have a common superclass. The Simulator is tightly coupled to the specific classes. –It ‘knows’ a lot about the behavior of foxes and rabbits.

09/12/2004Lecture 9: Abstraction Techniques29 The Animal superclass Place common fields in Animal : –age, alive, location Method renaming to support information hiding: –run and hunt become act. Simulator can now be significantly decoupled.

09/12/2004Lecture 9: Abstraction Techniques30 Revised (decoupled) iteration for(Iterator iter = animals.iterator(); iter.hasNext(); ) { Animal animal = (Animal)iter.next(); if(animal.isAlive()) { animal.act(field, updatedField, newAnimals); } else { iter.remove(); }

09/12/2004Lecture 9: Abstraction Techniques31 The act method of Animal Static type checking requires an act method in Animal. There is no obvious shared implementation. Define act as abstract: abstract public void act(Field currentField, Field updatedField, List newAnimals);

09/12/2004Lecture 9: Abstraction Techniques32 Abstract classes and methods Abstract methods have abstract in the signature. Abstract methods have no body. Abstract methods make the class abstract. Abstract classes cannot be instantiated. Concrete subclasses complete the implementation.

09/12/2004Lecture 9: Abstraction Techniques33 The Animal class public abstract class Animal { fields omitted /** * Make this animal act - that is: make it do * whatever it wants/needs to do. */ abstract public void act(Field currentField, Field updatedField, List newAnimals); other methods omitted }

09/12/2004Lecture 9: Abstraction Techniques34 More abstract methods public boolean canBreed() { return age >= getbreedingAge() } abstract public int getBreedingAge(); Note: fields are handled differently from methods in Java: they cannot be overridden by subclass version –both Rabbit and Fox have their own static field BREEDING_AGE and Animal has none.

09/12/2004Lecture 9: Abstraction Techniques35 Further abstraction

09/12/2004Lecture 9: Abstraction Techniques36 Selective drawing (multiple inheritance) // let all animals act for(Iterator iter = actors.iterator(); iter.hasNext();) { Actor actor = (Actor) iter.next(); actor.act(…); } for(Iterator iter = drawables.iterator(); iter.hasNext();) { Drawable item = (Drawable) iter.hasNext(); item.draw(…); }

09/12/2004Lecture 9: Abstraction Techniques37 Selective drawing (multiple inheritance)

09/12/2004Lecture 9: Abstraction Techniques38 Multiple inheritance Having a class inherit directly from multiple ancestors. Each language has its own rules. –How to resolve competing definitions? Java forbids it for classes. Java permits it for interfaces. –No competing implementation.

09/12/2004Lecture 9: Abstraction Techniques39 An Actor interface public interface Actor { /** * Perform the actor's daily behavior. * Transfer the actor to updatedField if it is * to participate in further steps of the simulation. currentField The current state of the field. location The actor's location in the field. updatedField The updated state of the field. */ void act(Field currentField, Location location, Field updatedField); }

09/12/2004Lecture 9: Abstraction Techniques40 Interfaces A Java interface is a specification of a type (in the form of a type name and methods) that does not define any implementation of methods uses interface instead of class all methods are public (no need to mention) all methods are abstract (no need to mention) no constructors all constant fields are allowed (public static final)

09/12/2004Lecture 9: Abstraction Techniques41 Classes implement an interface public class Fox extends Animal implements Drawable {... } public class Hunter implements Actor, Drawable {... }

09/12/2004Lecture 9: Abstraction Techniques42 Interfaces as types Implementing classes do not inherit code, but implementing classes are subtypes of the interface type. So, polymorphism is available with interfaces as well as classes.

09/12/2004Lecture 9: Abstraction Techniques43 Interfaces as specifications Strong separation of functionality from implementation. –Though parameter and return types are mandated. Clients interact independently of the implementation. –But clients can choose from alternative implementations.

09/12/2004Lecture 9: Abstraction Techniques44 Alternative implementations

09/12/2004Lecture 9: Abstraction Techniques45 Review Inheritance can provide shared implementation. –Concrete and abstract classes. Inheritance provides shared type information. –Classes and interfaces.

09/12/2004Lecture 9: Abstraction Techniques46 Review Abstract methods allow static type checking without requiring implementation. Abstract classes function as incomplete superclasses. –No instances. Abstract classes support polymorphism.

09/12/2004Lecture 9: Abstraction Techniques47 Interfaces Interfaces provide specification without implementation. –Interfaces are fully abstract. Interfaces support polymorphism. Java interfaces support multiple inheritance.

09/12/2004Lecture 9: Abstraction Techniques48 Concepts abstract class interfaces instanceof