470 likes | 494 Views
System development with Java. Instructors: Rina Zviel-Girshin Lecture 6. Inheritance. Inheritance Subclasses Overriding Object class. Inheritance Idea. Creation of new software from existing software components by adding only . You create objects of your class inside a new class.
E N D
System development with Java Instructors: Rina Zviel-Girshin Lecture 6 Rina Zviel-Girshin @ARC
Inheritance • Inheritance • Subclasses • Overriding • Object class Rina Zviel-Girshin @ARC
Inheritance Idea • Creation of new software from existing software components by adding only. • You create objects of your class inside a new class. • This is called composition. • New class composed of objects of existing classes. Rina Zviel-Girshin @ARC
Inheritance • Inheritance allows us to derive new classes from existing ones. • The existing class is called superclass. • The class that does the inheriting is said to be a subclass of the class from which it inherits. • Sometimes the terms derived class and base class are used instead of subclass and superclass. Rina Zviel-Girshin @ARC
Inheritance • Instances of the derived class inherits all the properties and functionality that are defined in base class. • A derived class can add to the state and behavior that it inherits. • It can also replace or modify inherited behavior. Rina Zviel-Girshin @ARC
Example Some examples of superclasses and subclasses: Rina Zviel-Girshin @ARC
Rules of Thumb • Inheritance creates is-a relation. • ColoredPoint is a Point. • Everything that can be done with a Point object can be done with ColoredPoint object. • ColoredPoint has all the functionality of a Point and some more. Rina Zviel-Girshin @ARC
Example Rina Zviel-Girshin @ARC
Another example Student - is a person who studies in the university or college. CS Student - is a person who studies computer science in the university or college. CS female Student – is a person who studies computer science in the university or college and it’s gender is female. CS female student in IDC - is a person who studies computer science in IDC and it’s gender is female. Rina Zviel-Girshin @ARC
Another example • Student is a superclass of CS Student is a superclass CS female Student is a superclass CS female student in IDC. • CS female student in IDC is a subclass of CS female Student is a subclass of CS Student is a subclass of Student. Rina Zviel-Girshin @ARC
Creating a subclass • A keyword extends used to show that the current class is a subclass of other class. • Usually we try to extend the superclass data and methods by adding new features. Syntax: class ClassName extends SuperClassName { // additions to, and modifications of stuff inherited // from super class } Rina Zviel-Girshin @ARC
Example /** * A ColoredPoint class represents a Point object * with new data field color. */ public class ColoredPoint extends Point { private Color color; // … } Rina Zviel-Girshin @ARC
Example • Subclass can also have new methods. public class ColoredPoint extends Point { private Color color; // new method void setColor(Color color) { this.color = color; } } Rina Zviel-Girshin @ARC
Inherit & Extend • Inherit: Instances of the derived class inherit all the properties and functionality that is defined in the base class (all data and methods). • Extending: Usually, the derived class adds more functionality and properties. Rina Zviel-Girshin @ARC
Private Members • When you derive a class from a given base class: • The subclass inherits all the fields of the base class • It inherits all the methods of the base class • Private fields and methods in the base class are inherited but they cannot be accessed directly from the code of the subclass. They are private and encapsulated in the base class itself. Rina Zviel-Girshin @ARC
Subclass • Subclass can do one of the following with each inherited method: • use the method as it is • change it’s implementation – override • Subclass can also have methods and data of his own, i.e. add methods. Rina Zviel-Girshin @ARC
Example Rina Zviel-Girshin @ARC
Constructors • Constructors are not inherited. • Constructors must be redefined. • We often want to use the parent's constructor to set up the "parent's part" of the object. • We do this by using the super keyword. • A subclass constructor needs to indicate which parent constructor to connect to. Example super(x,y); // uses two integer constructor of Point Rina Zviel-Girshin @ARC
Example public class ColoredPoint extends Point { … // constructor public ColoredPoint(int x, int y,Color color) { super(x,y); this.color=color; } } Constructor of the Point class Rina Zviel-Girshin @ARC
The default constructor • The default constructor is empty constructor. • If a given class does not have a constructor a default constructor is used by the compiler. • If a subclass does not have a constructor then an empty constructor of superclass is invoked and an empty constructor of subclass itself. Rina Zviel-Girshin @ARC
The super keyword • The keyword super allows to refer to the parent (super) class. • The super keyword can be used to access the method from the subclass. • The first line of the constructor must invoke one of superclass constructors using super(..). • If you do not call super(..) in the first line of the constructor the compiler automatically invoke the empty default constructor of the superclass. Rina Zviel-Girshin @ARC
Example public class ColoredPoint extends Point { … // ColoredPoint constructor s public ColoredPoint(int x, int y,Color color){ super(x,y); // constructor of the Point class this.color=color; // additional information } public ColoredPoint(int x, int y){ super(x,y); // constructor of the Point class } …} Rina Zviel-Girshin @ARC
Overriding • Overriding means changing the implementation of the method while keeping it’s signature. • Subclass can override a method implementation to provide a different version than parent. • Subclass can add some information to parent version of the method. • Subclass can completely re-define the parent’s method. Rina Zviel-Girshin @ARC
Overriding • Example: We want clients to be able to open a protected file only if it is unlocked • File(String name) • isOpen() • open() • close() • getName() File • RestrictedFile(String name, long key) • isLocked() • lock() • unlock(long key) RestrictedFile Rina Zviel-Girshin @ARC
File Example /** * Part of a File implementation */ public class File { // The name of the file private String name; // true if the file is opened private boolean isOpen; /** * Construct a file with a given name. */ public File(String name) { this.name = name; } Rina Zviel-Girshin @ARC
File Example /** * Returns the name of the file. */ public String getName() { return name; } /** * Checks if the file is open. * @return true iff the file is open */ public boolean isOpen() { return isOpen; } // other methods/variables... } Rina Zviel-Girshin @ARC
File Example /** * Opens the file. */ public void open() { // … other operations isOpen = true; } /** * Closes the file. */ public void close() { // … other operations isOpen = false; } } Rina Zviel-Girshin @ARC
RestrictedFile Example /** * Represents a restricted file, which can be opened * only if it is unlocked. In order to unlock * the file a key is needed. */ public class RestrictedFile extends File { // Password for unlocking the file private long key; // The state of the file - locked/unlocked private boolean isLocked; /** * Constructs a new restricted file. * @param key The key to unlock the file */ public RestrictedFile(String name, long key) { super(name); this.key = key; isLocked = true; } Rina Zviel-Girshin @ARC
RestrictedFile Example /** * Checks if the file is locked. */ public boolean isLocked() { return isLocked; } /** * Locks the file. */ public void lock() { isLocked = true; } Rina Zviel-Girshin @ARC
RestrictedFile Example /** * Unlock the file. The file will be unlocked only * if the given key matches. * @param key the key to unlock the file */ public void unlock(long key) { if (this.key == key) { isLocked = false; } } • So far the implementation is useless if we do not change the implementation of open() Rina Zviel-Girshin @ARC
RestrictedFile Example /** * Open the file. The file will be opened only if it * is unlocked. */ public void open() { if (!isLocked()) { super.open(); } } Rina Zviel-Girshin @ARC
Overriding in RestrictedFile • RestrictedFile inherits the interface of File, but changes the functionality of the method open(). • We say that RestrictedFileoverrides the method open(). • Notice the call to super.open() - we invoke the method open() of the superclass on this object. • The new method can use super to call the inherited method. • Syntax: super.method(); Rina Zviel-Girshin @ARC
Rules of Overriding • When you derive a class B from a class A, the interface of class B will be a superset of that of class A (except for constructors) • You cannot remove a method from the interface by subclassing (explain why...) • However, class B can override some of the methods that it inherits and thus change their functionality. • The contract of a method states what is expected from an overriding implementation of the method. Rina Zviel-Girshin @ARC
Visibility modifiers • Visibility modifiers determine which class members get inherited and which do not, which members are accessible and which are not. • Any member (variable,method and constructor) can be declared with one of the 4 visibility modifiers: • public • private • protected • default (none) Rina Zviel-Girshin @ARC
Visibility modifiers • public – accessible anywhere, inherited by all subclasses of its class. • private – only code of the same class in which the member has been defined can access this member, inherited by subclasses of its class but can not be accessed directly from the code of the subclass. • protected – accessible by any class in the same package as its class, inherited by all subclasses of its class. • default – accessible by any class in the same package as its class, inherited by any class in the same package. Rina Zviel-Girshin @ARC
Inheritance • Several classes can be declared as subclasses of the same superclass. • These subclasses share some structures and behaviors - the ones they inherit from their common superclass. • The superclass expresses these shared structures and behaviors. • Inheritance can also extend over several "generations" of classes. Rina Zviel-Girshin @ARC
Inheritance • In the diagram class E is a subclass of class D which is itself a subclass of class A. In this case, class E is considered to be a subclass of class A, even though it is not a direct subclass. • Inheritance mechanism is transitive. Rina Zviel-Girshin @ARC
The Object Class • Java defines the class java.lang.Object that is defined as a superclass for all classes. • All classes directly or indirectly extend the Object class. • If a class does not specify explicitly which class it is derived from, then it will be implicitly derived from class Object. • All classes inherit Object’s methods. Rina Zviel-Girshin @ARC
Hierarchy Diagram Object • We can depict the relationship between this classes in the following diagram, that is called class hierarchy diagram. Point ColoredPoint Rina Zviel-Girshin @ARC
The Object Class • The following two class definitions are equivalent: class SomeClass { // some code } and class SomeClass extends Object { // some code } Because all classes derived from the Object. Rina Zviel-Girshin @ARC
Methods of Object Class • The Object class defines a set of methods that are inherited by all classes. • Some of them are: equals(Object o), getClass(), toString() • toString() method that is used whenever we want to get a String representation of an object. • When you define a new class, you can override the toString() method in order to have a suitable representation of the new type of objects as Strings. Rina Zviel-Girshin @ARC
Overriding toString() public class Point { private int x,y; public Point(int x, int y) { this.x=x; this.y=y; } public int getx() {return x;} public int gety() {return y;} public String toString() { return "(" + x + "," + y + ")"; } } Rina Zviel-Girshin @ARC
Overriding toString() public class ColoredPoint extends Point { private Color color; public ColoredPoint(int x, int y,Color color) { super(x,y); this.color=color; } void setColor(Color color) { this.color = color; } public String toString() { return "(" + getx() + "," + gety() + "," + color + ")"; } } Rina Zviel-Girshin @ARC
Overriding toString() import java.awt.Color; class PrintingPointExample { public static void main(String[] args) { ColoredPoint p = new ColoredPoint(2,3,Color.red); System.out.println(p); } } Rina Zviel-Girshin @ARC
Overloading vs. Overriding • Overloading deals with multiple methods in the same class with the same name but different signatures. • Overriding deals with two methods, one in a parent class and one in a child class, that have the same signature. • Overloading lets you define a similar operation in different ways for different data. • Overriding lets you define a similar operation in different ways for different object types. Rina Zviel-Girshin @ARC
Multiple inheritance • Multiple inheritance means that a derived class can have more than one parent. • Exist in some-object oriented languages, like C++. • Java’s approach to inheritance is single inheritance. • Only one extends allowed. • Usually you can avoid the need for multiple inheritance with good design of the class hierarchy. • But there are other solutions in Java (through interfaces). Rina Zviel-Girshin @ARC
Any Questions? Rina Zviel-Girshin @ARC