Data Abstraction - Interfaces and Implementations Cmput 115 - Lecture 1 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some.

Slides:



Advertisements
Similar presentations
Copyright 2008 by Pearson Education Building Java Programs Chapter 8 Lecture 8-3: Encapsulation, toString reading: self-checks: #13-18,
Advertisements

Inheritance Inheritance Reserved word protected Reserved word super
Doubly-Linked Lists Cmput Lecture 16 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based.
Ordered Containers Cmput Lecture 21 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based.
Road Map Introduction to object oriented programming. Classes
Container Traversal Cmput Lecture 20 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based.
Self-Reference - Induction Cmput Lecture 7 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some code in this lecture is.
1 Classes Overview l Classes as Types l Declaring Instance Variables l Implementing Methods l Constructors l Accessor and Mutator Methods.
1 Lecture 06(Abstract Classes)Lecture 9 Abstract Classes Overview  Abstract Classes: A Definition.  Declaring Abstract Classes.  Abstract Methods: A.
Stacks Cmput Lecture 18 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based on code from.
Circularly-Linked Lists Cmput Lecture 17 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based.
Exceptions Cmput Lecture 3 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some code in this lecture is based on code from.
Self-Reference - Recursion Cmput Lecture 6 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some code in this lecture is.
Object (Data and Algorithm) Analysis Cmput Lecture 5 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some code in this.
1 Introduction to CS Agenda Syllabus Schedule Lecture: the management of complexity.
Copyright 2006 by Pearson Education 1 Building Java Programs Chapter 8: Classes and Objects.
Terms and Rules Professor Evan Korth New York University (All rights reserved)
Code Clarity - Comments, Preconditions and Postconditions Cmput Lecture 2 Department of Computing Science University of Alberta ©Duane Szafron 1999.
Cmput Lecture 15 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based on code from the book:
Queues Cmput Lecture 19 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based on code from.
The List Interface Cmput Lecture 14 Department of Computing Science University of Alberta ©Duane Szafron 2000 Some code in this lecture is based.
DRY. 11: DRY—Don’t Repeat Yourself Every piece of knowledge should have a single, unambiguous, authoritative representation within a system Duplication.
1 More on Classes Overview l Overloading l The this keyword l The toString method l The equals method.
OOP Languages: Java vs C++
Inheritance using Java
Object Oriented Programming Concepts OOP – reasoning about a program as a set of objects rather than as a set of actions Object – a programming entity.
Copyright 2008 by Pearson Education Building Java Programs Chapter 8 Lecture 8-2: Constructors and Encapsulation reading: self-checks: #10-17.
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.
CSCI-383 Object-Oriented Programming & Design Lecture 13.
Copyright 2008 by Pearson Education Building Java Programs Chapter 8 Lecture 8-3: Encapsulation, this reading: self-checks: #13-17 exercises:
CPSC 102: Computer Science II Dr. Roy P. Pargas 408 Edwards Hall Office Hours 10:00-11:00 am MWF 2:00-3:00 pm TTh.
Copyright 2010 by Pearson Education Building Java Programs Chapter 8 Lecture 8-2: Object Behavior (Methods) and Constructors, Encapsulation, this reading:
Ordered Containers CMPUT Lecture 19 Department of Computing Science University of Alberta ©Duane Szafron 2003 Some code in this lecture is based.
Object-Oriented Design CSC 212. Announcements This course is speeding up and we are starting new material. Please see me if you feel this is going too.
CSSE501 Object-Oriented Development. Chapter 4: Classes and Methods  Chapters 4 and 5 present two sides of OOP: Chapter 4 discusses the static, compile.
Summing Up Object Oriented Design. Four Major Components: Abstraction modeling real-life entities by essential information only Encapsulation clustering.
COP INTERMEDIATE JAVA Designing Classes. Class Template or blueprint for creating objects. Their definition includes the list of properties (fields)
Chapter 5 Classes and Methods II Lecture Slides to Accompany An Introduction to Computer Science Using Java (2nd Edition) by S.N. Kamin, D. Mickunas, E.
Inheritance CSI 1101 Nour El Kadri. OOP  We have seen that object-oriented programming (OOP) helps organizing and maintaining large software systems.
Application development with Java Lecture 21. Inheritance Subclasses Overriding Object class.
Chapter 7 Classes and Methods III: Static Methods and Variables Lecture Slides to Accompany An Introduction to Computer Science Using Java (2nd Edition)
POLYMORPHISM Chapter 6. Chapter Polymorphism  Polymorphism concept  Abstract classes and methods  Method overriding  Concrete sub classes and.
OOP Basics Classes & Methods (c) IDMS/SQL News
Structured Programming Dr. Atif Alhejali Lecture 4 Modifiers Parameters passing 1Structured Programming.
© 2004 Pearson Addison-Wesley. All rights reserved April 10, 2006 Inheritance (part 2) ComS 207: Programming I (in Java) Iowa State University, SPRING.
Classes CS 162 (Summer 2009). Parts of a Class Instance Fields Methods.
Copyright 2010 by Pearson Education Building Java Programs Chapter 8 Lecture 8-3: Constructors; Encapsulation reading: self-checks: #13-18,
Geoff Holmes and Bernhard Pfahringer COMP206-08S General Programming 2.
Copyright 2010 by Pearson Education Building Java Programs Chapter 8 Lecture 8-2: Object Behavior (Methods) and Constructors, Encapsulation, this reading:
Object Oriented Programming. Constructors  Constructors are like special methods that are called implicitly as soon as an object is instantiated (i.e.
OOP: Encapsulation &Abstraction
תרגול מספר 9: הורשה מחלקות אבסטרקטיות חריגים
Inheritance ITI1121 Nour El Kadri.
Lecture 12 Inheritance.
COP 3331 Object Oriented Analysis and Design Chapter 5 – Classes and Inheritance Jean Muhammad.
Chapter 3: Using Methods, Classes, and Objects
MIT AITI 2003 Lecture 8 Class And Object II.
תרגול מספר 9: הורשה מחלקות אבסטרקטיות חריגים
OBJECT ORIENTED PROGRAMMING II LECTURE 8 GEORGE KOUTSOGIANNAKIS
Topic 28 classes and objects, part 2
Building Java Programs
Topic 29 classes and objects, part 3
Building Java Programs
Building Java Programs
Handout-4b More on Classes
Java Programming Language
Building Java Programs
Dr. R Z Khan Handout-3 Classes
Building Java Programs
Chapter 11 Inheritance and Encapsulation and Polymorphism
Presentation transcript:

Data Abstraction - Interfaces and Implementations Cmput Lecture 1 Department of Computing Science University of Alberta ©Duane Szafron 1999 Some code in this lecture is based on code from the book: Java Structures by Duane A. Bailey or the companion structure package Revised 12/16/99

©Duane Szafron About This Lecture In this lecture we will learn how Java objects and classes can be used to build abstract data types.

©Duane Szafron Outline Object Concepts Interface Use Implementation Java interfaces

©Duane Szafron What is an Object? some thing that has: - identity - state - set of defined behaviours * operations (methods) the object does * requests operations (methods) other objects do Example Object: student (061342, Mary Doe, 1st year, Computing Science, 12 Bellvue Towers, takes CMPUT 115, swims, gets a computer account)

©Duane Szafron What is a Class? share a set of things that share (have in common): - an identification technique - state variables - set of defined behaviours * operations (methods) the object does * requests operations (methods) other objects do Example Class: student class (student id, name, year, program, address, *, takes courses, activities*, special needs*)

©Duane Szafron Abstraction/Generalization/Specialization student’ class (student id, name, year, program, address, takes courses) cmput-student class is a subclass of student’( , gets a computer account) phys-ed-student class is a subclass of student’(activities) student’ cmput-studentphys-ed-student isa

©Duane Szafron Objects are everywhere!

©Duane Szafron Types of Objects Objects in the “real world” User interface objects - e.g., windows, mouse drivers System objects - e.g., server, clients, proxies Persistent management objects - e.g., files, databases, versions, configurations User objects - e.g., user preferences

©Duane Szafron Example of Data Structure Object Properties of queue - request is serviced from the front of the queue, new requests are placed at the rear of the queue. Implement a queue of players wishing to make their next move. Develop a computer game in which resources are either shared or competed for between players. How do you manage these resources? A common way is to use a queue. Queue player = new QueueList() // create a queue of players player.add(name) // add a player to the queue player-done = player.remove //remove a player from the queue

©Duane Szafron Object Concepts An object has a public interface and a private state. The interface is the set of all resources the class provides. Objects that share the same interface are organized into a group called a class and each object in the class is called an instance of the class. (object = instance of a class) The state of an object differentiates it from other objects in the same class.

©Duane Szafron class Object Class, Interface and State public interface private state public interface private state public interface private state external request public interface private state

©Duane Szafron Interface, Implementation & Use There are three aspects for any class: –Interface: a description of the resources that the class provides. –Implementation: the code that describes the private state of instances and implements the computational resources of the class. –Use: code in a using class causes new instances of the used class to be created and invokes computations on these instances.

©Duane Szafron Interface In Java, the interface of a class includes: –The name of the superclass –Public variable declarations –Constructor declarations –Message declarations –Static method declarations Note that in Java, the term interface has a specific meaning that is slightly different than our generic use of the term interface. We will discuss Java interfaces later.

©Duane Szafron Interface - Ratio Class -1 public class Ratio { /* an object for storing a fraction */ public Ratio(int top, int bottom) /* pre: bottom != 0 post: constructs a ratio equivalent to top/bottom */ public int getNumerator() /* post: return the numerator of the fraction */ public int getDenominator() /* post: return the denominator of the fraction */ Do not be concerned about the “pre:” and “post:” notation. It will be explained in the next lecture. code based on Bailey pg. 8

©Duane Szafron Interface - Ratio Class -2 public double value() /* post: returns the real value equivalent to ratio */ public Ratio add(Ratio other) /* pre: other is non-null post: return new fraction - the sum of this and other */ code based on Bailey pg. 9

©Duane Szafron Use In Java, a class A can use another class B by: –Creating instances of class B. –Sending messages to instances of class B. –Invoking static methods from class B. –Using variables that are declared in class B. –Using message arguments that are declared to be of class B.

©Duane Szafron Use - Ratio Class public static void main(String[] args) { Ratio r = new Ratio(1,1); // r == 1.0 r = new Ratio(1,2); // r == 0.5 r.add(new Ratio(1,3)); // r still 0.5 r = r.add(new Ratio(1,4)); // r == 0.75 System.out.println(r.value()); // 0.75 printed } code based on Bailey pg. 9

©Duane Szafron Implementation In Java, a class implementation includes: –Constructor code –Message code (instance methods) –Static (class) method code –Bindings for static variables

©Duane Szafron Implementation - Ratio Class -1 import structure.*; public class Ratio { /* an object for storing a fraction */ protected int numerator; // numerator of ratio protected int denominator; // denominator of ratio public Ratio(int top, int bottom) { /* pre: bottom != 0 post: constructs a ratio equivalent to top/bottom */ Assert.pre(bottom != 0, "Denominator must not be 0"); this.numerator = top; this.denominator = bottom; } code based on Bailey pg. 8

©Duane Szafron Implementation - Ratio Class -2 public int getNumerator() { /* post: return the numerator of the fraction */ return this.numerator; } public int getDenominator() { /* post: return the denominator of the fraction */ return this.denominator; } code based on Bailey pg. 8

©Duane Szafron Implementation - Ratio Class -3 public double value() { /* post: returns the real value equivalent to ratio */ return (double)this.numerator /(double)this.denominator; } public Ratio add(Ratio other) { /* pre: other is non-null post: return new fraction - the sum of this and other */ Assert.pre(other != null, "Other must not be null"); return new Ratio(this.numerator*other.denominator+ this.denominator*other.numerator, this.denominator*other.denominator); } code based on Bailey pg. 9

©Duane Szafron Java Interfaces For many classes, the interface and the implementation are in the same file. However, Java has a specific feature called an interface that can be used to separate the interface of a class from its implementation. This is not usually done! A Java interface contains no code, only message signatures.

©Duane Szafron Java Interface - PlanarPoint -1 public interface PlanarPoint { public double getX(); /* post: returns the x coordinate. */ public double getY(); /* post: returns the y coordinate. */ public double getR(); /* post: returns the distance from the origin. */ public double getTheta(); /* post: returns the angle in radians from the x axis. */

©Duane Szafron Graphical Interpretation X Y  R (x,y) (r,  )

©Duane Szafron Java Interface - PlanarPoint -2 public void transform(double dr, double dTheta); /* pre: if dr >= 0 or |dr| < current r post: changes the r and theta coordinates by adding the given values to them. */ public void translate(double dx, double dy); /* post: changes the x and y coordinates by adding the given values to them. */ public PlanarPoint add(PlanarPoint aPoint); /* pre: aPoint is non-null post: return new PlanarPoint - the sum of this and other */ }

©Duane Szafron Implementing Java Interfaces A Java class is used to implement a Java interface. The class must provide code for each message in the Java interface. The class name must be different from the Java interface name.

©Duane Szafron Class - CartesianPoint -1 public class CartesianPoint implements PlanarPoint { protected double x; // x coordinate of point protected double y; // y coordinate of point public CartesianPoint(double x, double y) { /* post: constructs a Point with the given coordinates */ this.x = x; this.y = y; } PlanarPoint CartesianPoint PolarPoint

©Duane Szafron Class - CartesianPoint -2 public double getX() { /* post: returns the x coordinate. */ return this.x; } public double getY() { /* post: returns the y coordinate. */ return this.y; }

©Duane Szafron Class - CartesianPoint -3 public double getR() { /* post: returns the distance from the origin. */ return Math.sqrt((this.x*this.x) + (this.y*this.y)); }

©Duane Szafron Class - CartesianPoint -4 public double getTheta() { /* post: returns the angle in radians from the x axis. */ double angle; angle = Math.atan(this.y/this.x); if (this.x < 0) angle = angle + Math.PI; return angle; }

©Duane Szafron Graphical Interpretation X Y R (x,y) Assume x < 0 (r,  +  )   ++

©Duane Szafron Class - CartesianPoint -5 public void transform(double dr, double dTheta) { /* pre: if dr < 0 then |dr| < current r post: changes the r and theta coordinates by adding the given values to them. */ double r; double theta; Assert.pre((dr>=0)|| (Math.abs(dr) <= this.getR()), ”require that dr >= 0 or abs(dr) <= r"); r = this.getR() + dr; theta = this.getTheta() + dTheta; this.x = r * Math.cos(theta); this.y = r * Math.sin(theta); }

©Duane Szafron Graphical Interpretation X Y  (r 1,   )  (r 1 +r 2,   +   ) Transform Method

©Duane Szafron Class - CartesianPoint -6 public void translate(double dx, double dy) { /* post: changes the x and y coordinates by adding the given values to them. */ this.x = this.x + dx; this.y = this.y + dy; }

©Duane Szafron Class - CartesianPoint -7 public PlanarPoint add(PlanarPoint aPoint) { /* pre: other is non-null post: return new PlanarPoint - the sum of this and other */ Assert.pre(other != null, "Other must not be null"); return new CartesianPoint(this.x + aPoint.getX(), this.y + aPoint.getY()); } /* Note that we cannot use aPoint.x or aPoint.y since aPoint might not be a Cartesian Point. It may be an instance of some other class that implements the PlanarPoint interface. */ }

©Duane Szafron Multiple Classes can Implement a Java Interface We can have an arbitrary number of classes that implement the same interface. For example, we could have another class that implements the PlanarPoint interface, named the PolarPoint class (see the web for code). We can declare variables to be the Interface type, but must create instances of the implementation classes to bind them to.

©Duane Szafron Using PlanarPoint public void main(String args[]) { PlanarPoint cartPoint, polarPoint, sumPoint; cartPoint = new CartesianPoint(3.0, 4.0); polarPoint = new PolarPoint(5.0, Math.atan(4.0 / 3.0)); sumPoint = cartPoint.add(polarPoint); System.out.println(sumPoint); /*(6.0, 8.0) */ sumPoint = polarPoint.add(cartPoint); System.out.println(sumPoint); /* */ } X Y  (r 1,   )  (r 1 +r 2,   +   ) (3.0,4.0) (3+3, 4+4)

©Duane Szafron Some Principles from the Textbook 1.The principled programmer understands a principle well enough to form an opinion about it. 2.Free the future: reuse code. 3.Design and abide by the interfaces as though you were the user. 4. Declare the data fields protected-- that way you cannot access them from outside the class and you are forced to access through the interface. principles from Bailey ch. 1