Modern Programming Languages

Slides:



Advertisements
Similar presentations
Containers CMPS Reusable containers Simple data structures in almost all nontrivial programs Examples: vectors, linked lists, stacks, queues, binary.
Advertisements

DATA STRUCTURES Lecture: Interfaces Slides adapted from Prof. Steven Roehrig.
Object Orientation Chapter SixteenModern Programming Languages, 2nd ed.1 Spring 2012.
Object Orientation Chapter SixteenModern Programming Languages, 2nd ed.1.
A Second Look At Java Chapter FifteenModern Programming Languages, 2nd ed.1.
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.
Georgia Institute of Technology Workshop for CS-AP Teachers Chapter 3 Advanced Object-Oriented Concepts.
C8: Understanding Inheritance. Intuitive description Intuitive: FLORISTS are SHOPKEEPERS, inheriting various shopkeeper behaviors Tension in OOP languages:
George Blank University Lecturer. CS 602 Java and the Web Object Oriented Software Development Using Java Chapter 4.
ISBN Chapter 11 Abstract Data Types and Encapsulation Concepts.
Stacks (Revised and expanded from CIT 591). What is a stack? A stack is a Last In, First Out (LIFO) data structure Anything added to the stack goes on.
Stacks. 2 What is a stack? A stack is a Last In, First Out (LIFO) data structure Anything added to the stack goes on the “top” of the stack Anything removed.
Lecture 9 Concepts of Programming Languages
Abstract Data Types and Encapsulation Concepts
Topic 3 The Stack ADT.
Chapter 3 Introduction to Collections – Stacks Modified
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.
Generalized Containers CSIS 3701: Advanced Object Oriented Programming.
Programming Languages and Paradigms Object-Oriented Programming (Part II)
What is inheritance? It is the ability to create a new class from an existing class.
Some Other Collections: Bags, Sets, Queues and Maps COMP T2 Lecture 4 School of Engineering and Computer Science, Victoria University of Wellington.
Programming Languages by Ravi Sethi Chapter 6: Groupings of Data and Operations.
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.
Chapter 3 Inheritance and Polymorphism Goals: 1.Superclasses and subclasses 2.Inheritance Hierarchy 3.Polymorphism 4.Type Compatibility 5.Abstract Classes.
Stacks and Queues. 2 3 Runtime Efficiency efficiency: measure of computing resources used by code. can be relative to speed (time), memory (space), etc.
Chapter FifteenModern Programming Languages1 A Second Look At Java.
Chapter 6 Introduction to Defining Classes. Objectives: Design and implement a simple class from user requirements. Organize a program in terms of a view.
Slide 1 Linked Data Structures. Slide 2 Learning Objectives  Nodes and Linked Lists  Creating, searching  Linked List Applications  Stacks, queues.
Copyright © 2002 Pearson Education, Inc. Slide 1.
Chapter SixteenModern Programming Languages1 Object Orientation.
Application development with Java Lecture 21. Inheritance Subclasses Overriding Object class.
Introduction to Object-Oriented Programming Lesson 2.
Inheritance Type/Subtype Relationship. Inheritance Idea: An object B of one type, termed child class, inherits from another object A of another type,
Classes, Interfaces and Packages
Terms and Rules II Professor Evan Korth New York University (All rights reserved)
 Description of Inheritance  Base Class Object  Subclass, Subtype, and Substitutability  Forms of Inheritance  Modifiers and Inheritance  The Benefits.
CSC 243 – Java Programming, Spring, 2014 Week 4, Interfaces, Derived Classes, and Abstract Classes.
Click to edit Master text styles Stacks Data Structure.
Java Programming: Guided Learning with Early Objects Chapter 9 Inheritance and Polymorphism.
Stacks and Queues. 2 Abstract Data Types (ADTs) abstract data type (ADT): A specification of a collection of data and the operations that can be performed.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2008 Pearson Education, Inc., Upper.
Linked Data Structures
Principles of programming languages 10: Object oriented languages
Building Java Programs
Inheritance and Polymorphism
Lecture 12 Inheritance.
Abstract Data Types and Encapsulation Concepts
Inheritance and Polymorphism
03/10/14 Inheritance-2.
11.1 The Concept of Abstraction
The Stack ADT. 3-2 Objectives Define a stack collection Use a stack to solve a problem Examine an array implementation of a stack.
Inheritance "Question: What is the object oriented way of getting rich? Answer: Inheritance.“ “Inheritance is new code that reuses old code. Polymorphism.
Lecture 9 Concepts of Programming Languages
Understanding Inheritance
Stacks and Queues.
Abstract Data Types and Encapsulation Concepts
Stacks.
Java Programming Language
Defining Classes and Methods
Stacks.
CIS 199 Final Review.
Interfaces.
Defining Classes and Methods
Review of Previous Lesson
Lecture 10 Concepts of Programming Languages
Stacks and Queues.
Inheritance Lakshmish Ramaswamy.
Lecture 9 Concepts of Programming Languages
Chapter 11 Abstraction - The concept of abstraction is fundamental in
Presentation transcript:

Modern Programming Languages A Second Look At Java Chapter Fifteen Modern Programming Languages

Modern Programming Languages Subtype Polymorphism Person x; Does this declare x to be a reference to an object of the Person class? Not exactly—the type Person may include references to objects of other classes Java has subtype polymorphism Chapter Fifteen Modern Programming Languages

Modern Programming Languages Outline 15.2 Implementing interfaces 15.3 Extending classes 15.4 Extending and implementing 15.5 Multiple inheritance 15.6 Generics Chapter Fifteen Modern Programming Languages

Modern Programming Languages Interfaces A method prototype just gives the method name and type—no method body An interface in Java is a collection of method prototypes public interface Drawable { void show(int xPos, int yPos); void hide(); } Chapter Fifteen Modern Programming Languages

Implementing Interfaces A class can declare that it implements a particular interface Then it must provide public method definitions that match those in the interface Chapter Fifteen Modern Programming Languages

Modern Programming Languages Examples public class Icon implements Drawable { public void show(int x, int y) { … method body … } public void hide() { … method body … } …more methods and fields… } public class Square implements Drawable, Scalable { … all required methods of all interfaces implemented … } Chapter Fifteen Modern Programming Languages

Modern Programming Languages Why Use Interfaces? An interface can be implemented by many classes: Interface name can be used as a reference type: public class Window implements Drawable … public class MousePointer implements Drawable … public class Oval implements Drawable … Drawable d; d = new Icon("i1.gif"); d.show(0,0); d = new Oval(20,30); d.show(0,0); Chapter Fifteen Modern Programming Languages

Polymorphism With Interfaces static void flashoff(Drawable d, int k) { for (int i = 0; i < k; i++) { d.show(0,0); d.hide(); } } Class of object referred to by d is not known at compile time It is some class that implements Drawable, so it has show and hide methods that can be called Chapter Fifteen Modern Programming Languages

A More Complete Example A Worklist interface for a collection of String objects Can be added to, removed from, and tested for emptiness Chapter Fifteen Modern Programming Languages

Modern Programming Languages public interface Worklist { /** * Add one String to the worklist. * @param item the String to add */ void add(String item); /** * Test whether there are more elements in the * worklist: that is, test whether more elements * have been added than have been removed. * @return true iff there are more elements */ boolean hasMore(); Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * Remove one String from the worklist and return * it. There must be at least one element in the * worklist. * @return the String item removed */ String remove(); } Chapter Fifteen Modern Programming Languages

Interface Documentation Comments are especially important in an interface, since there is no code to help the reader understand what each method is supposed to do Worklist interface does not specify ordering: could be a stack, a queue, or something else We will do an implementation as a stack, implemented using linked lists Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * A Node is an object that holds a String and a link * to the next Node. It can be used to build linked * lists of Strings. */ public class Node { private String data; // Each node has a String... private Node link; // and a link to the next Node /** * Node constructor. * @param theData the String to store in this Node * @param theLink a link to the next Node */ public Node(String theData, Node theLink) { data = theData; link = theLink; } Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * Accessor for the String data stored in this Node. * @return our String item */ public String getData() { return data; } /** * Accessor for the link to the next Node. * @return the next Node */ public Node getLink() { return link; } } Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * A Stack is an object that holds a collection of * Strings. */ public class Stack implements Worklist { private Node top = null; // top Node in the stack /** * Push a String on top of this stack. * @param data the String to add */ public void add(String data) { top = new Node(data,top); } Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * Test whether this stack has more elements. * @return true if this stack is not empty */ public boolean hasMore() { return (top!=null); } /** * Pop the top String from this stack and return it. * This should be called only if the stack is * not empty. * @return the popped String */ public String remove() { Node n = top; top = n.getLink(); return n.getData(); } } Chapter Fifteen Modern Programming Languages

Modern Programming Languages A Test Worklist w; w = new Stack(); w.add("the plow."); w.add("forgives "); w.add("The cut worm "); System.out.print(w.remove()); System.out.print(w.remove()); System.out.println(w.remove()); Output: The cut worm forgives the plow. Other implementations of Worklist are possible: Queue, PriorityQueue, etc. Chapter Fifteen Modern Programming Languages

Modern Programming Languages Outline 15.2 Implementing interfaces 15.3 Extending classes 15.4 Extending and implementing 15.5 Multiple inheritance 15.6 Generics Chapter Fifteen Modern Programming Languages

Modern Programming Languages More Polymorphism Another, more complex source of polymorphism One class can be derived from another, using the keyword extends For example: a class PeekableStack that is just like Stack, but also has a method peek to examine the top element without removing it Chapter Fifteen Modern Programming Languages

Modern Programming Languages /** * A PeekableStack is an object that does everything a * Stack can do, and can also peek at the top element * of the stack without popping it off. */ public class PeekableStack extends Stack { /** * Examine the top element on the stack, without * popping it off. This should be called only if * the stack is not empty. * @return the top String from the stack */ public String peek() { String s = remove(); add(s); return s; } } Chapter Fifteen Modern Programming Languages

Modern Programming Languages Inheritance Because PeekableStack extends Stack, it inherits all its methods and fields (Nothing like this happens with interfaces—when a class implements an interface, all it gets is an obligation) In addition to inheritance, you also get polymorphism Chapter Fifteen Modern Programming Languages

Modern Programming Languages Stack s1 = new PeekableStack(); PeekableStack s2 = new PeekableStack(); s1.add("drive"); s2.add("cart"); System.out.println(s2.peek()); Note that s1.peek() is not legal here, even though s1 is a reference to a PeekableStack. It is the static type of the reference, not the object’s class, that determines the operations Java will permit. Chapter Fifteen Modern Programming Languages

Modern Programming Languages Question Our peek was inefficient: Why not just do this? public String peek() { String s = remove(); add(s); return s; } public String peek() { return top.getData(); } Chapter Fifteen Modern Programming Languages

Modern Programming Languages Answer The top field of Stack is private PeekableStack cannot access it For more efficient peek, Stack must make top visible in classes that extend it protected instead of private A common design challenge for object-oriented languages: designing for reuse by inheritance Chapter Fifteen Modern Programming Languages

Modern Programming Languages Inheritance Chains A derived class can have more classes derived from it All classes but one are derived from some class If you do not give an extends clause, Java supplies one: extends Object Object is the ultimate base class in Java Chapter Fifteen Modern Programming Languages

Modern Programming Languages The Class Object All classes are derived, directly or indirectly, from the predefined class Object (except Object itself) All classes inherit methods from Object: toString, for converting to a String equals, for comparing with other objects hashcode, for computing an int hash code etc. Chapter Fifteen Modern Programming Languages

Overriding Inherited Definitions Sometimes you want to redefine an inherited method No special construct for this: a new method definition automatically overrides an inherited definition of the same name and type Chapter Fifteen Modern Programming Languages

Modern Programming Languages Overriding Example System.out.print(new Stack()); The inherited toString just combines the class name and hash code (in hexadecimal) So the code above prints something like: Stack@b3d A custom toString method in Stack can override this with a nicer string: public String toString() { return "Stack with top at " + top; } Chapter Fifteen Modern Programming Languages

Inheritance Hierarchies Inheritance forms a hierarchy, a tree rooted at Object Sometimes inheritance is one useful class extending another In other cases, it is a way of factoring out common code from different classes into a shared base class Chapter Fifteen Modern Programming Languages

Modern Programming Languages public class Label { private int x,y; private int width; private int height; private String text; public void move (int newX, int newY) { x = newX; y = newY; } public String getText() { return text; } } public class Icon { private int x,y; private int width; private int height; private Gif image; public void move (int newX, int newY) { x = newX; y = newY; } public Gif getImage() { return image; } } Two classes with a lot in common—but neither is a simple extension of the other. Chapter Fifteen Modern Programming Languages

Modern Programming Languages public class Graphic { protected int x,y; protected int width,height; public void move(int newX, int newY) { x = newX; y = newY; } } public class Label extends Graphic { private String text; public String getText() { return text; } } public class Icon extends Graphic { private Gif image; public Gif getImage() { return image; } } Common code and data have been factored out into a common base class. Chapter Fifteen Modern Programming Languages

Modern Programming Languages A Design Problem When you write the same statements repeatedly, you think: that should be a method When you write the same methods repeatedly, you think: that should be a common base class The real trick is to see the need for a shared base class early in the design, before writing a lot of code that needs to be reorganized Chapter Fifteen Modern Programming Languages

Subtypes and Inheritance A derived class is a subtype From Chapter Six: When designing class hierarchies, think about inheritance of functionality Not all intuitively reasonable hierarchies work well for inheriting functionality A subtype is a subset of the values, but it can support a superset of the operations. Chapter Fifteen Modern Programming Languages

Modern Programming Languages Outline 15.2 Implementing interfaces 15.3 Extending classes 15.4 Extending and implementing 15.5 Multiple inheritance 15.6 Generics Chapter Fifteen Modern Programming Languages

Extending And Implementing Classes can use extends and implements together For every class, the Java language system keeps track of several properties, including: A: the interfaces it implements B: the methods it is obliged to define C: the methods that are defined for it D: the fields that are defined for it Chapter Fifteen Modern Programming Languages

Simple Cases For A Class A method definition affects C only A field definition affects D only An implements part affects A and B All the interfaces are added to A All the methods in them are added to B A: the interfaces it implements B: the methods it is obliged to define C: the methods that are defined for it D: the fields that are defined for it Chapter Fifteen Modern Programming Languages

Modern Programming Languages Tricky Case For A Class An extends part affects all four: All interfaces of the base class are added to A All methods the base class is obliged to define are added to B All methods of the base class are added to C All fields of the base class are added to D A: the interfaces it implements B: the methods it is obliged to define C: the methods that are defined for it D: the fields that are defined for it Chapter Fifteen Modern Programming Languages

Modern Programming Languages Previous Example public class Stack implements Worklist {…} public class PeekableStack extends Stack {…} PeekableStack has: A: Worklist interface, inherited B: obligations for add, hasMore, and remove, inherited C: methods add, hasMore, and remove, inherited, plus its own method peek D: field top, inherited Chapter Fifteen Modern Programming Languages

Modern Programming Languages A Peek At abstract Note that C is a superset of B: the class has definitions of all required methods Java ordinarily requires this Classes can get out of this by being declared abstract An abstract class is used only as a base class; no objects of that class are created We will not be using abstract classes Chapter Fifteen Modern Programming Languages

Modern Programming Languages Outline 15.2 Implementing interfaces 15.3 Extending classes 15.4 Extending and implementing 15.5 Multiple inheritance 15.6 Generics Chapter Fifteen Modern Programming Languages

Modern Programming Languages Multiple Inheritance In some languages (such as C++) a class can have more than one base class Seems simple at first: just inherit fields and methods from all the base classes For example: a multifunction printer Chapter Fifteen Modern Programming Languages

Modern Programming Languages Collision Problem The different base classes are unrelated, and may not have been designed to be combined Scanner and Fax might both have a method named transmit When MultiFunction.transmit is called, what should happen? Chapter Fifteen Modern Programming Languages

Modern Programming Languages Diamond Problem A class may inherit from the same base class through more than one path If A defines a field x, then B has one and so does C Does D get two of them? Chapter Fifteen Modern Programming Languages

Modern Programming Languages Solvable, But… A language that supports multiple inheritance must have mechanisms for handling these problems Not all that tricky The question is, is the additional power worth the additional language complexity? Java’s designers did not think so Chapter Fifteen Modern Programming Languages

Living Without Multiple Inheritance One benefit of multiple inheritance is that a class can have several unrelated types (like Copier and Fax) This can be done in Java by using interfaces: a class can implement any number of interfaces Another benefit is inheriting implementation from multiple base classes This is harder to accomplish with Java Chapter Fifteen Modern Programming Languages

Modern Programming Languages Forwarding public class MultiFunction { private Printer myPrinter; private Copier myCopier; private Scanner myScanner; private Fax myFax; public void copy() { myCopier.copy(); } public void transmitScanned() { myScanner.transmit(); } public void sendFax() { myFax.transmit(); } … } Chapter Fifteen Modern Programming Languages

Modern Programming Languages Outline 15.1 Implementing interfaces 15.2 Extending classes 15.3 Extending and implementing 15.4 Multiple inheritance 15.5 Generics Chapter Fifteen Modern Programming Languages

Modern Programming Languages No Generic Classes Previous Stack example: a stack of strings Can’t be reused for stacks of other types In ML we used type variables for this: Ada and C++ have something similar, also in Java since JDK 1.5 datatype 'a node = NULL | CELL of 'a * 'a node; Chapter Fifteen Modern Programming Languages

Living Without Generics We can make a stack whose element type is Object The type Object includes all references, so this will allow any objects to be placed in the stack Chapter Fifteen Modern Programming Languages

Modern Programming Languages public class GenericNode { private Object data; private GenericNode link; public GenericNode(Object theData, GenericNode theLink) { data = theData; link = theLink; } public Object getData() { return data; } public GenericNode getLink() { return link; } } Similarly, we could define GenericStack (and a GenericWorklist interface) using Object in place of String Chapter Fifteen Modern Programming Languages

Modern Programming Languages Weaknesses To recover the type of the stacked object, we will have to use an explicit type cast: This is a pain to write, and also inefficient Java checks at runtime that the type cast is legal—the object really is a String GenericStack s1 = new GenericStack(); s1.add("hello"); String s = (String) s1.remove(); Chapter Fifteen Modern Programming Languages

Modern Programming Languages Weaknesses Primitive types must first be stored in an object before being stacked: Again, laborious and inefficient Integer is a predefined wrapper class There is one for every primitive type GenericStack s2 = new GenericStack(); s2.add(new Integer(1)); int i = ((Integer) s2.remove()).intValue(); Chapter Fifteen Modern Programming Languages

Modern Programming Languages True Generics There are many proposals to add generics to Java: parameterized polymorphic classes (and interfaces) Perhaps using a notation like C++ templates Chapter Fifteen Modern Programming Languages

Modern Programming Languages public class Stack<T> implements Worklist<T> { private Node<T> top = null; public void add(T data) { top = new Node<T>(data,top); } public boolean hasMore() { return (top!=null); } public T remove() { Node<T> n = top; top = n.getLink(); return n.getData(); } } Chapter Fifteen Modern Programming Languages

Modern Programming Languages Using Generic Classes Stack<String> s1 = new Stack<String>(); Stack<int> s2 = new Stack<int>(); s1.add("hello"); String s = s1.remove(); s2.add(1); int i = s2.remove(); Now part of Java since JDK 1.5 Chapter Fifteen Modern Programming Languages