© 2004 Pearson Addison-Wesley. All rights reserved November 7, 2007 Interfaces ComS 207: Programming I (in Java) Iowa State University, FALL 2007 Instructor:

Slides:



Advertisements
Similar presentations
Interfaces A Java interface is a collection
Advertisements

Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
Chapter 5: Keyboard I/O & Simple GUI’s Copyright 2002, Matthew Evett. These slides are based on slides copyrighted by John Lewis and William Loftus, 2002,
Fall 2007CS 2251 Enum Types from Java Software Solutions Foundations of Program Design Sixth Edition by Lewis & Loftus.
ECE122 L16: Class Relationships April 3, 2007 ECE 122 Engineering Problem Solving with Java Lecture 16 Class Relationships.
Abstract Classes.
Chapter 5: Enhancing Classes Presentation slides for Java Software Solutions Foundations of Program Design Second Edition by John Lewis and William Loftus.
Classes, Encapsulation, Methods and Constructors
Aalborg Media Lab 28-Jun-15 Software Design Lecture 7 “Object Oriented Design”
Interfaces A Java interface is a collection of constants and abstract methods with a name that looks like a class name, i.e. first letter is capitalized.
INF 523Q Chapter 5: Enhancing Classes. 2 b We can now explore various aspects of classes and objects in more detail b Chapter 5 focuses on: object references.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley John Lewis, Peter DePasquale, and Joseph Chase Chapter 5: Writing Classes.
Object Oriented Design and UML
Writing Classes (Chapter 4)
CSE 1301 Lecture 11 Object Oriented Programming Figures from Lewis, “C# Software Solutions”, Addison Wesley Richard Gesick.
Chapter 6 Object-Oriented Design. © 2004 Pearson Addison-Wesley. All rights reserved6-2 Object-Oriented Design Now we can extend our discussion of the.
© 2004 Pearson Addison-Wesley. All rights reserved November 9, 2007 Method Design & Method Overloading ComS 207: Programming I (in Java) Iowa State University,
6-1 Object-Oriented Design Today we focuses on: –the this reference (Chapter 7) –the static modifier (Chapter 7) –method overloading (Chapter 7)
CSE 1302 Lecture 7 Object Oriented Programming Review Richard Gesick.
Chapter 6 Object-Oriented Design Part 1. © 2004 Pearson Addison-Wesley. All rights reserved2/42 Object-Oriented Design Now we can extend our discussion.
1 Object Oriented Design and UML Class Relationships –Dependency –Aggregation –Inheritance Reading for this Lecture: L&L 6.4 – 6.5.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
Chapter 7 Object-Oriented Design Concepts
6. Object-Oriented Design Based on Java Software Development, 5 th Ed. By Lewis &Loftus.
6. Object-Oriented Design Based on Java Software Development, 5 th Ed. By Lewis &Loftus.
Programming in Java (COP 2250) Lecture 14 & 15 Chengyong Yang Fall, 2005.
Java Software Solutions Foundations of Program Design Sixth Edition by Lewis & Loftus Chapter 6: Object-Oriented Design.
1 Object Oriented Design and UML Class Relationships –Dependency –Aggregation –Interfaces –Inheritance Interfaces Reading for this Lecture: L&L 6.4 – 6.5.
Chapter 6 Object-Oriented Design. © 2004 Pearson Addison-Wesley. All rights reserved6-2 Object-Oriented Design Now we can extend our discussion of the.
Static class members.
© 2004 Pearson Addison-Wesley. All rights reserved September 12, 2007 Encapsulation ComS 207: Programming I (in Java) Iowa State University, FALL 2007.
© 2004 Pearson Addison-Wesley. All rights reserved September 14, 2007 Anatomy of a Method ComS 207: Programming I (in Java) Iowa State University, FALL.
1 Object-Oriented Design Now we can extend our discussion of the design of classes and objects Chapter 6 focuses on: software development activities determining.
Chapter 6 Object-Oriented Design Part 2. © 2004 Pearson Addison-Wesley. All rights reserved2/20 The this Reference The this reference allows an object.
© 2004 Pearson Addison-Wesley. All rights reserved April 14, 2006 Polymorphism ComS 207: Programming I (in Java) Iowa State University, SPRING 2006 Instructor:
1 Object-Oriented Design Now we can extend our discussion of the design of classes and objects Chapter 6 focuses on: software development activities determining.
Chapter 8 Inheritance 5 TH EDITION Lewis & Loftus java Software Solutions Foundations of Program Design © 2007 Pearson Addison-Wesley. All rights reserved.
Designing Classes Chapter 3. Contents Encapsulation Specifying Methods Java Interfaces – Writing an Interface – Implementing an Interface – An Interface.
Programming in Java (COP 2250) Lecture 10 Chengyong Yang Fall, 2005.
Interfaces. In order to work with a class, you need to understand the public methods  methods, return types,…  after you instantiate, what can you do.
1 Lecture 8 b Data Structures b Abstraction b The “Structures” package b Preconditions and postconditions b Interfaces b Polymorphism b Vector class b.
© 2004 Pearson Addison-Wesley. All rights reserved November 12, 2007 Inheritance ComS 207: Programming I (in Java) Iowa State University, FALL 2007 Instructor:
Outline Software Development Activities Identifying Classes and Objects Static Variables and Methods Class Relationships Interfaces Enumerated Types Revisited.
© 2004 Pearson Addison-Wesley. All rights reserved April 10, 2006 Inheritance (part 2) ComS 207: Programming I (in Java) Iowa State University, SPRING.
© 2004 Pearson Addison-Wesley. All rights reserved January 23, 2006 Creating Objects & String Class ComS 207: Programming I (in Java) Iowa State University,
© 2004 Pearson Addison-Wesley. All rights reserved November 14, 2007 Inheritance (part 2) ComS 207: Programming I (in Java) Iowa State University, FALL.
© 2004 Pearson Addison-Wesley. All rights reserved September 5, 2007 Packages & Random and Math Classes ComS 207: Programming I (in Java) Iowa State University,
© 2004 Pearson Addison-Wesley. All rights reserved April 5, 2006 Method Design & Method Overloading ComS 207: Programming I (in Java) Iowa State University,
Object-Oriented Design Chapter 7 1. Objectives You will be able to Use the this reference in a Java program. Use the static modifier for member variables.
2/23- Interfaces Reference: Java 6.5 and 9.3. PA-4 Review Requirements PA3 – Grading Key PA4 Requirements Doc.
© 2004 Pearson Addison-Wesley. All rights reserved November 2, 2007 Class Relationships ComS 207: Programming I (in Java) Iowa State University, FALL 2007.
Object-Oriented Design. Static Class Members Recall that a static method is one that can be invoked through its class name For example, the methods of.
University of Turkish Aeronautical Association Computer Engineering Department CENG 112 COMPUTER PROGRAMMING 2 Tansel Dökeroglu, Ph.D.
Copyright © 2012 Pearson Education, Inc. Chapter 4 Writing Classes : Review Java Software Solutions Foundations of Program Design Seventh Edition John.
Chapter 5: Enhancing Classes
Interfaces November 6, 2006 ComS 207: Programming I (in Java)
Creating Objects & String Class
Inheritance November 10, 2006 ComS 207: Programming I (in Java)
Passing Objects to Methods
More Object Oriented Programming
Object Oriented Programming
Inheritance April 7, 2006 ComS 207: Programming I (in Java)
Abstract Class As per dictionary, abstraction is the quality of dealing with ideas rather than events. For example, when you consider the case of ,
Chapter 5: Enhancing Classes
CSE 501N Fall ‘09 13: Interfaces and Multiple Representation
Object Oriented Programming Review
Object-Oriented Design Part 2
Presentation transcript:

© 2004 Pearson Addison-Wesley. All rights reserved November 7, 2007 Interfaces ComS 207: Programming I (in Java) Iowa State University, FALL 2007 Instructor: Alexander Stoytchev

© 2004 Pearson Addison-Wesley. All rights reserved Quick Review of Last Lecture

© 2004 Pearson Addison-Wesley. All rights reserved Objects – instances of a class with a static variable ‘size’ int weight= 170;int weight= 130; obj1obj2 static int size;

© 2004 Pearson Addison-Wesley. All rights reserved Objects – instances of classes Note that the variables can have different values in the two objects int size =5; int weight= 170; int size =10; int weight= 130;

© 2004 Pearson Addison-Wesley. All rights reserved Static Class Members The order of the modifiers can be interchanged, but by convention visibility modifiers come first Recall that the main method is static – it is invoked by the Java interpreter without creating an object Static methods cannot reference instance variables because instance variables don't exist until an object exists However, a static method can reference static variables or local variables

© 2004 Pearson Addison-Wesley. All rights reserved Static Class Members Recall that a static method is one that can be invoked through its class name For example, the methods of the Math class are static: result = Math.sqrt(25); Variables can be static as well Determining if a method or variable should be static is an important design decision

© 2004 Pearson Addison-Wesley. All rights reserved Static Methods class Helper { public static int cube (int num) { return num * num * num; } Because it is declared as static, the method can be invoked as value = Helper.cube(5);

© 2004 Pearson Addison-Wesley. All rights reserved myMethod(); myMethodcompute Method Control Flow If the called method is in the same class, only the method name is needed

© 2004 Pearson Addison-Wesley. All rights reserved myMethod(); myMethodcompute Accessing Variables If the called method is in the same class, only the method name is needed int myVariable; myVariable=5; OK

© 2004 Pearson Addison-Wesley. All rights reserved myMethod(); myMethodcompute Accessing Variables Static methods cannot use non static class variables. int myVariable; myVariable=5; Error static

© 2004 Pearson Addison-Wesley. All rights reserved myMethod(); myMethodcompute Accessing Variables Static methods can use static class varables static int myVariable; myVariable=5; OK static

© 2004 Pearson Addison-Wesley. All rights reserved Class Helper static cube static helpMe helpMe(); Helper.cube(); main Method Control Flow Static methods can only call other static methods within the same classs

Chapter 6 Section 6.4

© 2004 Pearson Addison-Wesley. All rights reserved Class Relationships Classes in a software system can have various types of relationships to each other Three of the most common relationships:  Dependency: A uses B  Aggregation: A has-a B  Inheritance: A is-a B

© 2004 Pearson Addison-Wesley. All rights reserved Dependency A dependency exists when one class relies on another in some way, usually by invoking the methods of the other We've seen dependencies in many previous examples We don't want numerous or complex dependencies among classes Nor do we want complex classes that don't depend on others A good design strikes the right balance

© 2004 Pearson Addison-Wesley. All rights reserved Dependency Example: Client-Server

© 2004 Pearson Addison-Wesley. All rights reserved Dependency Some dependencies occur between objects of the same class A method of the class may accept an object of the same class as a parameter For example, the concat method of the String class takes as a parameter another String object str3 = str1.concat(str2); This drives home the idea that the service is being requested from a particular object

© 2004 Pearson Addison-Wesley. All rights reserved concat(String s) Concatenation Example str1str2 concat(String s)

© 2004 Pearson Addison-Wesley. All rights reserved Dependency The following example defines a class called Rational to represent a rational number A rational number is a value that can be represented as the ratio of two integers Some methods of the Rational class accept another Rational object as a parameter See RationalTester.java (page 297)RationalTester.java See Rational.java (page 299)Rational.java

© 2004 Pearson Addison-Wesley. All rights reserved Representing Rational Numbers public class RationalNumber { private int numerator, denominator; // … }

© 2004 Pearson Addison-Wesley. All rights reserved Adding Two rational numbers public RationalNumber add (RationalNumber op2) { int commonDenominator = denominator *op2.getDenominator(); int numerator1 = numerator * op2.getDenominator(); int numerator2 = op2.getNumerator() * denominator; int sum = numerator1 + numerator2; return new RationalNumber (sum, commonDenominator); }

© 2004 Pearson Addison-Wesley. All rights reserved Aggregation An aggregate is an object that is made up of other objects Therefore aggregation is a has-a relationship  A car has a chassis  A student has an address

© 2004 Pearson Addison-Wesley. All rights reserved Aggregation In software, an aggregate object contains references to other objects as instance data The aggregate object is defined in part by the objects that make it up This is a special kind of dependency – the aggregate usually relies on the objects that compose it

© 2004 Pearson Addison-Wesley. All rights reserved Aggregation Example: Copmonents of a Student

© 2004 Pearson Addison-Wesley. All rights reserved Student Home Address School Address First NameLast Name

© 2004 Pearson Addison-Wesley. All rights reserved john 21 Jump Street 800 Lancaster Ave. JohnSmith

© 2004 Pearson Addison-Wesley. All rights reserved marsha 123 Main Street 800 Lancaster Ave. MarshaJones

© 2004 Pearson Addison-Wesley. All rights reserved Aggregation In the following example, a Student object is composed, in part, of Address objects A student has an address (in fact each student has two addresses) See StudentBody.java (page 304)StudentBody.java See Student.java (page 306)Student.java See Address.java (page 307)Address.java An aggregation association is shown in a UML class diagram using an open diamond at the aggregate end

© 2004 Pearson Addison-Wesley. All rights reserved Other Stuff from Section 6.4

© 2004 Pearson Addison-Wesley. All rights reserved A More Complicated Student Example Home Address School Address Degree Program UniversityName

© 2004 Pearson Addison-Wesley. All rights reserved How would you write the code for the more complicated student example?

© 2004 Pearson Addison-Wesley. All rights reserved Inheritance is discussed in Chapter 8 Man Woman Abstract Person

© 2004 Pearson Addison-Wesley. All rights reserved Condo Mansion 5 bedroom house Abstract Home

© 2004 Pearson Addison-Wesley. All rights reserved The this Reference The this reference allows an object to refer to itself That is, the this reference, used inside a method, refers to the object through which the method is being executed Suppose the this reference is used in a method called tryMe, which is invoked as follows: obj1.tryMe(); obj2.tryMe(); In the first invocation, the this reference refers to obj1 ; in the second it refers to obj2

© 2004 Pearson Addison-Wesley. All rights reserved The this reference The this reference can be used to distinguish the instance variables of a class from corresponding method parameters with the same names The constructor of the Account class (from Chapter 4) could have been written as follows: public Account (Sring name, long acctNumber, double balance) { this.name = name; this.acctNumber = acctNumber; this.balance = balance; }

© 2004 Pearson Addison-Wesley. All rights reserved The this reference public Account (Sring name, long acctNumber, double balance) { this.name = name; this.acctNumber = acctNumber; this.balance = balance; } public Account (Sring owner, long account, double initial) { name = owner; acctNumber = account; balance = initial; }

Chapter 6 Section 6.5 – 6.6

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces A Java interface is a collection of abstract methods and constants An abstract method is a method header without a method body An abstract method can be declared using the modifier abstract, but because all methods in an interface are abstract, usually it is left off An interface is used to establish a set of methods that a class will implement

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces public interface Doable { public void doThis(); public void doThat(); public void doThis2 (float value, char ch); public boolean doTheOther (int num); } interface is a reserved word None of the methods in an interface are given a definition (body) A semicolon immediately follows each method header

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces An interface cannot be instantiated Methods in an interface have public visibility by default A class formally implements an interface by:  stating so in the class header  providing implementations for each abstract method in the interface If a class asserts that it implements an interface, it must define all methods in the interface

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces public class CanDo implements Doable { public void doThis () { // whatever } public void doThat () { // whatever } // etc. } implements is a reserved word Each method listed in Doable is given a definition

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces A class that implements an interface can implement other methods as well See Complexity.java (page 310)Complexity.java See Question.java (page 311)Question.java See MiniQuiz.java (page 313)MiniQuiz.java In addition to (or instead of) abstract methods, an interface can contain constants When a class implements an interface, it gains access to all its constants

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces A class can implement multiple interfaces The interfaces are listed in the implements clause The class must implement all methods in all interfaces listed in the header class ManyThings implements interface1, interface2 { // all methods of both interfaces }

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces The Java standard class library contains many helpful interfaces The Comparable interface contains one abstract method called compareTo, which is used to compare two objects We discussed the compareTo method of the String class in Chapter 5 The String class implements Comparable, giving us the ability to put strings in lexicographic order

© 2004 Pearson Addison-Wesley. All rights reserved Where ca you find the standard Java interfaces C:\Program Files\Java\jdk1.5.0\src.zip

© 2004 Pearson Addison-Wesley. All rights reserved The Comparable Interface Any class can implement Comparable to provide a mechanism for comparing objects of that type if (obj1.compareTo(obj2) < 0) System.out.println ("obj1 is less than obj2"); The value returned from compareTo should be negative is obj1 is less that obj2, 0 if they are equal, and positive if obj1 is greater than obj2 When a programmer designs a class that implements the Comparable interface, it should follow this intent

© 2004 Pearson Addison-Wesley. All rights reserved The Comparable Interface It's up to the programmer to determine what makes one object less than another For example, you may define the compareTo method of an Employee class to order employees by name (alphabetically) or by employee number The implementation of the method can be as straightforward or as complex as needed for the situation

© 2004 Pearson Addison-Wesley. All rights reserved The Iterator Interface As we discussed in Chapter 5, an iterator is an object that provides a means of processing a collection of objects one at a time An iterator is created formally by implementing the Iterator interface, which contains three methods The hasNext method returns a boolean result – true if there are items left to process The next method returns the next object in the iteration The remove method removes the object most recently returned by the next method

© 2004 Pearson Addison-Wesley. All rights reserved The Iterator Interface By implementing the Iterator interface, a class formally establishes that objects of that type are iterators The programmer must decide how best to implement the iterator functions Once established, the for-each version of the for loop can be used to process the items in the iterator

© 2004 Pearson Addison-Wesley. All rights reserved Interfaces You could write a class that implements certain methods (such as compareTo ) without formally implementing the interface ( Comparable ) However, formally establishing the relationship between a class and an interface allows Java to deal with an object in certain ways Interfaces are a key aspect of object-oriented design in Java We discuss this idea further in Chapter 9

© 2004 Pearson Addison-Wesley. All rights reserved Interface Example: Sortable.java SortableIntArray.java SortableStrigArray.java SortingTest.java

© 2004 Pearson Addison-Wesley. All rights reserved Enumerated Types (read on your own)

© 2004 Pearson Addison-Wesley. All rights reserved Enumerated Types In Chapter 3 we introduced enumerated types, which define a new data type and list all possible values of that type enum Season {winter, spring, summer, fall} Once established, the new type can be used to declare variables Season time; The only values this variable can be assigned are the ones established in the enum definition

© 2004 Pearson Addison-Wesley. All rights reserved Enumerated Types An enumerated type definition is a special kind of class The values of the enumerated type are objects of that type For example, fall is an object of type Season That's why the following assignment is valid time = Season.fall;

© 2004 Pearson Addison-Wesley. All rights reserved Enumerated Types An enumerated type definition can be more interesting than a simple list of values Because they are like classes, we can add additional instance data and methods We can define an enum constructor as well Each value listed for the enumerated type calls the constructor See Season.java (page 318)Season.java See SeasonTester.java (page 319)SeasonTester.java

© 2004 Pearson Addison-Wesley. All rights reserved Enumerated Types Every enumerated type contains a static method called values that returns a list of all possible values for that type The list returned from values is an iterator, so a for loop can be used to process them easily An enumerated type cannot be instantiated outside of its own definition A carefully designed enumerated type provides a versatile and type-safe mechanism for managing data

© 2004 Pearson Addison-Wesley. All rights reserved THE END