Chapter 10 Abstract Classes and Interfaces
Chapter 10 Abstract Classes and Interfaces
Chapter 10 Abstract Classes and Interfaces
Interfaces
Chapter 6 Arrays
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 1
Objectives
To design and use abstract classes (§10.2).
To process a calendar using the Calendar and GregorianCalendar classes (§10.3).
To declare interfaces to model weak inheritance relationships (§10.4).
To define a natural order using the Comparable interface (§10.4.1).
To know the similarities and differences between an abstract class and an
interface (§10.4.2).
To declare custom interfaces (§10.4.3).
(Optional) To enable objects cloneable using the Cloneable interface (§10.4.4).
To use wrapper classes (Byte, Short, Integer, Long, Float, Double, Character, and
Boolean) to wrap primitive data values into objects (§10.5).
(Optional) To use the BigInteger and BigDecimal classes for computing very
large numbers with arbitrary precisions (§10.5.6).
To create a generic sort method (§10.5).
To simplify programming using JDK 1.5 automatic conversion between primitive
types and wrapper class types (§10.6).
(Optional GUI) To handle GUI events (§10.7).
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 2
The abstract Modifier
The abstract class
– Cannot be instantiated
– Should be extended and implemented in
subclasses
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 3
From Chapter 9
GeometricObject
-color: String The color of the object (default: white).
-filled: boolean Indicates whether the object is filled with a color (default: false).
-dateCreated: java.util.Date The date when the object was created.
+GeometricObject() Creates a GeometricObject.
+getColor(): String Returns the color.
+setColor(color: String): void Sets a new color.
+isFilled(): boolean Returns the filled property.
+setFilled(filled: boolean): void Sets a new filled property.
+getDateCreated(): java.util.Date Returns the dateCreated.
+toString(): String Returns a string representation of this object.
Circle Rectangle
-radius: double -width: double
+Circle() -height: double
+Circle(radius: double) +Rectangle()
+getRadius(): double +Rectangle(width: double, height: double)
+setRadius(radius: double): void +getWidth(): double
+getArea(): double +setWidth(width: double): void
+getPerimeter(): double +getHeight(): double
+getDiameter(): double +setHeight(height: double): void
+getArea(): double
+getPerimeter(): double
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 4
Abstract Classes
GeometricObject
-color: String
-filled: boolean
-dateCreated: java.util.Date
The # sign indicates
protected modifer #GeometricObject()
+getColor(): String
+setColor(color: String): void
+isFilled(): boolean
+setFilled(filled: boolean): void
+getDateCreated(): java.util.Date
+toString(): String
+getArea(): double
+getPerimeter(): double
GeometricObject
Circle Rectangle
-radius: double -width: double Circle
+Circle() -height: double
+Circle(radius: double) +Rectangle()
+getRadius(): double +Rectangle(width: double, height: double) Rectangle
+setRadius(radius: double): void +getWidth(): double
+getDiameter(): double +setWidth(width: double): void
+getHeight(): double
+setHeight(height: double): void
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 5
NOTE
An abstract method cannot be contained in
a nonabstract class. If a subclass of an
abstract superclass does not implement all
the abstract methods, the subclass must be
declared abstract. In other words, in a
nonabstract subclass extended from an
abstract class, all the abstract methods
must be implemented, even if they are not
used in the subclass.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 6
NOTE
An abstract class cannot be instantiated
using the new operator, but you can still
define its constructors, which are invoked
in the constructors of its subclasses. For
instance, the constructors of
GeometricObject are invoked in the Circle
class and the Rectangle class.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 7
NOTE
A class that contains abstract methods
must be abstract. However, it is possible to
declare an abstract class that contains no
abstract methods. In this case, you cannot
create instances of the class using the new
operator. This class is used as a base class
for defining a new subclass.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 8
NOTE
A subclass can be abstract even if its
superclass is concrete. For example, the
Object class is concrete, but its subclasses,
such as GeometricObject, may be abstract.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 9
NOTE
A subclass can override a method from its
superclass to declare it abstract. This is
rare, but useful when the implementation
of the method in the superclass becomes
invalid in the subclass. In this case, the
subclass must be declared abstract.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 10
NOTE
You cannot create an instance from an
abstract class using the new operator, but
an abstract class can be used as a data
type. Therefore, the following statement,
which creates an array whose elements are
of GeometricObject type, is correct.
GeometricObject[] geo = new
GeometricObject[10];
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 11
Example: Using the GeometricObject
Class
Objective: This example creates two geometric
objects: a circle, and a rectangle, invokes the
equalArea method to check if the two objects
have equal area, and invokes the
displayGeometricObject method to display the
objects.
TestGeometricObject Run
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 12
The Abstract Calendar Class and Its
GregorianCalendar subclass
java.util.Calendar
#Calendar() Constructs a default calendar.
+get(field: int): int Returns the value of the given calendar field.
+set(field: int, value: int): void Sets the given calendar to the specified value.
+set(year: int, month: int, Sets the calendar with the specified year, month, and date. The month
dayOfMonth: int): void parameter is 0-based, that is, 0 is for January.
+getActualMaximum(field: int): int Returns the maximum value that the specified calendar field could have.
+add(field: int, amount: int): void Adds or subtracts the specified amount of time to the given calendar field.
+getTime(): java.util.Date Returns a Date object representing this calendar’s time value (million
second offset from the Unix epoch).
+setTime(date: java.util.Date): void Sets this calendar’s time with the given Date object.
java.util.GregorianCalendar
+GregorianCalendar() Constructs a GregorianCalendar for the current time.
+GregorianCalendar(year: int, Constructs a GregorianCalendar for the specified year, month, and day of
month: int, dayOfMonth: int) month.
+GregorianCalendar(year: int, Constructs a GregorianCalendar for the specified year, month, day of
month: int, dayOfMonth: int, month, hour, minute, and second. The month parameter is 0-based, that
hour:int, minute: int, second: int) is, 0 is for January.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 13
The Abstract Calendar Class and Its
GregorianCalendar subclass
An instance of java.util.Date represents a specific
instant in time with millisecond precision.
java.util.Calendar is an abstract base class for
extracting detailed information such as year, month,
date, hour, minute and second from a Date object.
Subclasses of Calendar can implement specific
calendar systems such as Gregorian calendar, Lunar
Calendar and Jewish calendar. Currently,
java.util.GregorianCalendar for the Gregorian
calendar is supported in the Java API.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 14
The GregorianCalendar Class
You can use new GregorianCalendar() to construct
a default GregorianCalendar with the current time
and use new GregorianCalendar(year, month, date)
to construct a GregorianCalendar with the specified
year, month, and date. The month parameter is 0-
based, i.e., 0 is for January.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 15
The get Method in Calendar Class
The get(int field) method defined in the Calendar class is
useful to extract the value for a given time field. The time
fields are defined as constants such as YEAR, MONTH,
DATE, HOUR (for the 12-hour clock), HOUR_OF_DAY
(for the 24-hour clock), MINUTE, SECOND,
DAY_OF_WEEK (the day number within the current week
with 1 for Sunday), DAY_OF_MONTH (same as the
DATE value), DAY_OF_YEAR (the day number within
the current year with 1 for the first day of the year),
WEEK_OF_MONTH (the week number within the current
month), and WEEK_OF_YEAR (the week number within
the current year). For example, the following code
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 16
Optional Path
You may cover Chapter 12, “GUI Basics”, and
Chapter 13, “Graphics,” now. See the Chapter
Dependency Chart.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 17
Interfaces
An interface is a classlike construct that contains only
constants and abstract methods. In many ways, an interface
is similar to an abstract class, but an abstract class can
contain variables and concrete methods as well as constants
and abstract methods.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 19
Define Interfaces
Suppose you want to design a generic method to
find the larger of two objects. The objects can be
students, dates, or circles. Since compare methods
are different for different types of objects, you
need to define a generic compare method to
determine the order of the two objects. Then you
can tailor the method to compare students, dates, or
circles. For example, you can use student ID as the
key for comparing students, radius as the key for
comparing circles, and volume as the key for
comparing dates. You can use an interface to
define a generic compareTo method, as follows:
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 20
Example of an Interface
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 21
String and Date Classes
Many classes (e.g., String and Date) in the Java library
implement Comparable to define a natural order for the
objects. If you examine the source code of these classes,
you will see the keyword implements used in the classes,
as shown below:
public class String extends Object public class Date extends Object
implements Comparable { implements Comparable {
// class body omitted // class body omitted
} }
(a) (b)
ComparableRectangle
You cannot use the max method to find the larger of two instances of Rectangle,
because Rectangle does not implement Comparable. However, you can declare a
new rectangle class that implements Comparable. The instances of this new class
are comparable. Let this new class be named ComparableRectangle.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 25
Interfaces vs. Abstract Classes, cont.
All data fields are public final static and all methods are public abstract in an
interface. For this reason, these modifiers can be omitted, as shown below:
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 26
Interfaces vs. Abstract Classes, cont.
All classes share a single root, the Object class, but there is no single root for
interfaces. Like a class, an interface also defines a type. A variable of an interface
type can reference any instance of the class that implements the interface. If a class
extends an interface, this interface plays the same role as a superclass. You can use
an interface as a data type and cast a variable of an interface type to its subclass,
and vice versa.
Interface1_2 Interface2_2
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 28
Whether to use an interface or a class?
Abstract classes and interfaces can both be used to model common
features. How do you decide whether to use an interface or a class?
In general, a strong is-a relationship that clearly describes a parent-
child relationship should be modeled using classes. For example, a
staff member is a person. So their relationship should be modeled
using class inheritance. A weak is-a relationship, also known as an
is-kind-of relationship, indicates that an object possesses a certain
property. A weak is-a relationship can be modeled using interfaces.
For example, all strings are comparable, so the String class
implements the Comparable interface. You can also use interfaces
to circumvent single inheritance restriction if multiple inheritance is
desired. In the case of multiple inheritance, you have to design one
as a superclass, and others as interface. See Chapter 10, “Object-
Oriented Modeling,” for more discussions.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 29
Creating Custom Interfaces
public interface Edible {
/** Describe how to eat */
class abstract Fruit
public String howToEat();
implements Edible {
}
}
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 30
Implements Multiple Interfaces
class Chicken extends Animal implements Edible, Comparable {
int weight;
public Chicken(int weight) {
this.weight = weight;
}
public String howToEat() {
return "Fry it";
}
public int compareTo(Object o) {
return weight – ((Chicken)o).weight;
}
}
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 31
Creating Custom Interfaces, cont.
public interface Edible {
/** Describe how to eat */
public String howToEat();
}
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 32
The Cloneable Interfaces
Marker Interface: An empty interface.
A marker interface does not contain constants or methods.
It is used to denote that a class possesses certain desirable
properties. A class that implements the Cloneable
interface is marked cloneable, and its objects can be
cloned using the clone() method defined in the Object
class.
package java.lang;
public interface Cloneable {
}
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 33
Examples
Many classes (e.g., Date and Calendar) in the Java library implement
Cloneable. Thus, the instances of these classes can be cloned. For
example, the following code
House
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 35
Shallow vs. Deep Copy
House house1 = new House(1, 1750.50);
House house2 = (House)house1.clone();
id = 1 1
area = 1750.50 1750.50
whenBuilt reference whenBuilt: Date
id = 1 1
area = 1750.50 1750.50
whenBuilt reference
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 36
Wrapper Classes
Boolean Integer NOTE: (1) The wrapper classes do
not have no-arg constructors. (2)
Character Long The instances of all wrapper
classes are immutable, i.e., their
Short
Float
internal values cannot be changed
Double once the objects are created.
Byte
Comparable Object
- -
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 38
The Number Class
Each numeric wrapper class extends the
abstract Number class, which contains the
methods doubleValue, floatValue, intValue,
longValue, shortValue, and byteValue. These
methods “convert” objects into primitive type
values. The methods doubleValue, floatValue,
intValue, longValue are abstract. The methods
byteValue and shortValue are not abstract,
which simply return (byte)intValue() and
(short)intValue(), respectively.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 39
The Integer and Double Classes
java.lang.Number java.lang.Integer
-value: int
+byteValue(): byte +MAX_VALUE: int
+shortValue(): short +MIN_VALUE: int
+intValue(): int
+longVlaue(): long +Integer(value: int)
+floatValue(): float +Integer(s: String)
+doubleValue():double +valueOf(s: String): Integer
+valueOf(s: String, radix: int): Integer
+parseInt(s: String): int
java.lang.Comparable +parseInt(s: String, radix: int): int
+Double(value: double)
+Double(s: String)
+valueOf(s: String): Double
+valueOf(s: String, radix: int): Double
+parseDouble(s: String): double
+parseDouble (s: String, radix: int): double
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 40
The Integer Class
and the Double Class
Constructors
Conversion Methods
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 41
Numeric Wrapper Class Constructors
You can construct a wrapper object either from a
primitive data type value or from a string
representing the numeric value. The constructors
for Integer and Double are:
public Integer(int value)
public Integer(String s)
public Double(double value)
public Double(String s)
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 42
Numeric Wrapper Class Constants
Each numerical wrapper class has the constants
MAX_VALUE and MIN_VALUE. MAX_VALUE
represents the maximum value of the corresponding
primitive data type. For Byte, Short, Integer, and Long,
MIN_VALUE represents the minimum byte, short, int,
and long values. For Float and Double, MIN_VALUE
represents the minimum positive float and double values.
The following statements display the maximum integer
(2,147,483,647), the minimum positive float (1.4E-45),
and the maximum double floating-point number
(1.79769313486231570e+308d).
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 43
Conversion Methods
Each numeric wrapper class implements the
abstract methods doubleValue, floatValue,
intValue, longValue, and shortValue, which
are defined in the Number class. These
methods “convert” objects into primitive
type values.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 44
The Static valueOf Methods
The numeric wrapper classes have a useful
class method, valueOf(String s). This method
creates a new object initialized to the value
represented by the specified string. For
example:
Double doubleObject = Double.valueOf("12.4");
Integer integerObject = Integer.valueOf("12");
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 45
The Methods for Parsing Strings into
Numbers
You have used the parseInt method in the
Integer class to parse a numeric string into an
int value and the parseDouble method in the
Double class to parse a numeric string into a
double value. Each numeric wrapper class
has two overloaded parsing methods to parse
a numeric string into an appropriate numeric
value.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 46
Example: Sorting an Array of Objects
GenericSort Run
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 47
TIP
Java provides a static sort method for sorting an
array of Object in the java.util.Arrays class. So
you can use the following code to sort arrays in
this example:
java.util.Arrays.sort(intArray);
java.util.Arrays.sort(doubleArray);
java.util.Arrays.sort(charArray);
java.util.Arrays.sort(stringArray);
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 48
NOTE
Arrays are objects. An array is an instance of the
Object class. Furthermore, if A is a subclass of B,
every instance of A[] is an instance of B[].
Therefore, the following statements are all true:
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 50
JDK 1.5 Automatic Conversion Between Primitive
Feature
Types and Wrapper Class Types
JDK 1.5 allows primitive type and wrapper classes to be converted automatically. For
example, the following statement in (a) can be simplified as in (b):
Equivalent
Integer[] intArray = {new Integer(2), Integer[] intArray = {2, 4, 3};
new Integer(4), new Integer(3)};
Unboxing
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 51
NOTE to Instructor
Optional path:
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 52
Optional
GUI
Handling GUI Events
HandleEvent Run
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All righ
ts reserved. 0-13-148952-6 53
animation
Trace Execution
public class HandleEvent extends JFrame {
public HandleEvent() { 1. Start from the
… main method to
OKListenerClass listener1 = new OKListenerClass(); create a window and
jbtOK.addActionListener(listener1); display it
…
}