Time estimate: 90 min.

5.1. Inheritance, Superclass, Subclass

One of the really useful features of Object-Oriented programming is inheritance. You may have heard of someone coming into an inheritance, which often means they were left something from a relative who died. Or, you might hear someone say that they have inherited musical ability from a parent. In Java all classes can inherit attributes (instance variables) and behaviors (methods) from another class. The class being inherited from is called the parent class or superclass. The class that is inheriting is called the child class or subclass.

When one class inherits from another, we can say that it is the same kind of thing as the parent class (the class it inherits from). For example, a car is a kind of vehicle. This is sometimes called the is-a relationship, but more accurately it’s a is-a kind of relationship. A motorcycle is another kind of vehicle. All vehicles have a make, model, and year that they were created. All vehicles can go forward, backward, turn left and turn right.

../_images/vehicle.png

Figure 1: A UML Class Diagram Showing Inheritance

A UML (Unified Modeling Language) class diagram shows classes and the relationships between the classes as seen in Figure 1. An open triangle points to the parent class. The parent class for Car and Motorcycle is Vehicle. The Vehicle class has two child classes or subclasses: Car and Motorcycle.

5.1.1. Subclass extends Superclass

To make a subclass inherit from a superclass, use the Java keyword extends with the superclass name when creating a new subclass as shown below.

public class Car extends Vehicle
public class Motorcycle extends Vehicle

Note

While a person can have two parents, a Java class can only inherit from one parent class. If you leave off the extends keyword when you declare a class then the class will inherit from the Object class that is already defined in Java.

5.1.2. Why Use Inheritance?

Inheritance allows you to reuse data and behavior from the parent class. If you notice that several classes share the same data and/or behavior, you can pull that out into a parent class. This is called generalization. For example, Customers and Employees are both people so it makes sense use the general Person class as seen below.

Inheritance is also useful for specialization which is when you want most of the behavior of a parent class, but want to do at least one thing differently and/or add more data. The example below can also be seen as specialization. An employee is a person but also has a unique id. A customer is a person, but also has a credit card.

../_images/person.png

Figure 2: A UML Class Diagram Showing Inheritance

exercise Check your understanding

coding exercise Coding Exercise

The Student class can also inherit from the class Person just like Employee and Customer because a Student is a type of Person.

What do you need to add to the Student class declaration below to make it inherit from type Person? When you fix the code, the instanceof operator will return true that Student s is an instance of both the Student and the Person class. What other private instance variables could you add to Person and Student? In which class would you put an address attribute? Where would you put gpa?

5.1.3. is-a vs. has-a Relationships

Another type of relationship between classes is the has-a relationship or association relationship. Use this when the object of one class contains a reference to one or more of another class. For example, a course can have many course periods associated with it as shown below. The 1 near the Course means that 1 course object is associated with the number shown near the other class. In this case it is * which means 0 to many. So one course is associated with 0 to many course periods.

../_images/assoc.png

Figure 3: A UML Class Diagram showing Association

In the code, the Course class has an array or ArrayList of CoursePeriod objects as an attribute inside it.

public class Course
{
    private ArrayList<CoursePeriod> periodList;
}

Alternatively, we could say that a CoursePeriod has a Course attribute inside it to hold the information about the Course. It is up to the programmer how to design these two classes depending on which type of association would be more useful in the program.

public class CoursePeriod
{
    private Course courseInfo;
    private int period;
}

Here is another example. Consider the classes Student, Course, and APcourse. An APcourse is a special type of Course. Students are in Courses. What are the relationships between these classes? The UML diagram below shows the inherits (is-a) relationship between Course and APcourse and the associate (has-a) relationship between Course and Students.

../_images/APcourseUML.png

Figure 4: A UML Class Diagram for Student, Course, APcourse

coding exercise Coding Exercise

We can represent the diagram in Figure 4 in the code below. The Course class has an ArrayList of Student objects in it as the roster attribute. And an APcourse extends Course. What do you think the following code will print out?

What do you think the following code will print out?

5.1.4. is-a Substitution Test

If you aren’t sure if a class should inherit from another class ask yourself if you can substitute the subclass type for the superclass type. For example, if you have a Book class and it has a subclass of ComicBook does that make sense? Is a comic book a kind of book? Yes, a comic book is a kind of book so inheritance makes sense. If it doesn’t make sense use association or the has-a relationship instead.

Note

Only use inheritance when the child class is really a type of the parent class, otherwise use association.

exercise Check your understanding

5.1.5. groupwork Coding Challenge : Online Store

Working in pairs or groups, design an online store with classes for Store, ItemForSale, Book, Movie, and Author.

  • First, do some research in an online store like Amazon to see what information they store on books, movies, and authors, and what type of information is the same for all items for sale.

  • List at least 2 attributes for each class. Which attributes should be in ItemForSale and which in Book, Movie or Author?

  • What is the relationship between ItemForSale and Book? between ItemForSale and Movie? between Book and Author? between Store and ItemForSale? You may want to draw UML Class Diagrams for these classes on paper or using an online drawing tool like app.diagrams.net or Creately.com (choose UML Class Diagrams, click to connect classes and choose the relationship)

  • Use the ActiveCode window below to declare each class and specify their relationship to one another with inheritance or association. (Note that usually, each public class would be in a separate file, but since we only have 1 file in Active Code, we only make 1 class public). Only put in the instance variables for each class. We will learn how to make constructors and methods in the next lessons.

Declare at least 2 instance variables for each of the classes below. Create an inheritance or association relationship for some of them.

5.1.6. Summary

  • A class hierarchy can be developed by putting common attributes and behaviors of related classes into a single class called a superclass.

  • Classes that extend a superclass, called subclasses, can draw upon the existing attributes and behaviors of the superclass without repeating these in the code.

  • The keyword extends is used to establish an inheritance relationship between a subclass and a superclass. A class can extend only one superclass.

  • Extending a subclass from a superclass creates an is-a relationship from the subclass to the superclass.

You have attempted of activities on this page