Outline §Abstract class and interface §Inner classes and initialization blocks §Equality §Exception §Threads.

Slides:



Advertisements
Similar presentations
Chapter 17 Failures and exceptions. This chapter discusses n Failure. n The meaning of system failure. n Causes of failure. n Handling failure. n Exception.
Advertisements

Exception Handling Chapter 12.  Errors- the various bugs, blunders, typos and other problems that stop a program from running successfully  Natural.
Slides prepared by Rose Williams, Binghamton University ICS201 Exception Handling University of Hail College of Computer Science and Engineering Department.
Exception Handling. Introduction An exception is an abnormal condition that arises in a code sequence at run time. In computer languages that do not support.
Liang, Introduction to Java Programming, Eighth Edition, (c) 2011 Pearson Education, Inc. All rights reserved Inheritance and Polymorphism.
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 1 Abstract Classes and Interfaces.
George Blank University Lecturer. CS 602 Java and the Web Object Oriented Software Development Using Java Chapter 4.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved L19 (Chapter 24) Multithreading.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2005 Pearson Education, Inc. All rights reserved Chapter 9 Inheritance and.
Exceptions Three categories of errors: Syntax errors Runtime errors Logic errors Syntax errors: rules of the language have not been followed. Runtime error:
Exceptions in Java Fawzi Emad Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
1 Inheritance and Polymorphism. 2 Motivations Suppose you will define classes to model circles, rectangles, and triangles. These classes have many common.
Exceptions. Many problems in code are handled when the code is compiled, but not all Some are impossible to catch before the program is run  Must run.
1 Inheritance and Polymorphism Chapter 9. 2 Polymorphism, Dynamic Binding and Generic Programming public class Test { public static void main(String[]
Liang, Introduction to Java Programming, Tenth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 11 Inheritance and Polymorphism.
Chapter 6 Class Inheritance F Superclasses and Subclasses F Keywords: super F Overriding methods F The Object Class F Modifiers: protected, final and abstract.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 18 Exception Handling.
Chapter 12 Inheritance and Exceptions Lecture Slides to Accompany An Introduction to Computer Science Using Java (2nd Edition) by S.N. Kamin, D. Mickunas,
Object Oriented Programming
220 FINAL TEST REVIEW SESSION Omar Abdelwahab. INHERITANCE AND POLYMORPHISM Suppose you have a class FunClass with public methods show, tell, and smile.
CSM-Java Programming-I Spring,2005 Objects and Classes Overview Lesson - 1.
Liang, Introduction to Java Programming, Eighth Edition, (c) 2011 Pearson Education, Inc. All rights reserved COS240 O-O Languages AUBG,
Introduction to Object Oriented Programming. Object Oriented Programming Technique used to develop programs revolving around the real world entities In.
Chapter 15 Multithreading F Threads Concept  Creating Threads by Extending the Thread class  Creating Threads by Implementing the Runnable Interface.
Liang, Introduction to Java Programming, Fifth Edition, (c) 2005 Pearson Education, Inc. All rights reserved Chapter 19 Multithreading.
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 11 Inheritance and Polymorphism.
Inheritance and Polymorphism Daniel Liang, Introduction to Java Programming.
Java Threads. What is a Thread? A thread can be loosely defined as a separate stream of execution that takes place simultaneously with and independently.
Exception Handling Unit-6. Introduction An exception is a problem that arises during the execution of a program. An exception can occur for many different.
Exceptions in Java. Exceptions An exception is an object describing an unusual or erroneous situation Exceptions are thrown by a program, and may be caught.
Introduction to Threads Session 01 Java Simplified / Session 14 / 2 of 28 Objectives Define a thread Define multithreading List benefits of multithreading.
1 Abstract Classes and Interfaces. 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 rights reserved Chapter 9 Inheritance and.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 10 Inheritance and.
COP3502 Programming Fundamentals for CIS Majors 1 Instructor: Parisa Rashidi.
Exceptions and Assertions Chapter 15 – CSCI 1302.
Chapter 8 Class Inheritance and Interfaces F Superclasses and Subclasses  Keywords: super F Overriding methods  The Object Class  Modifiers: protected,
 In the java programming language, a keyword is one of 50 reserved words which have a predefined meaning in the language; because of this,
Exceptions in Java. What is an exception? An exception is an error condition that changes the normal flow of control in a program Exceptions in Java separates.
Interfaces F What is an Interface? F Creating an Interface F Implementing an Interface F What is Marker Interface?
Java Programming, Second Edition Chapter Twelve Advanced Inheritance Concepts.
Exceptions Handling Prepared by: Ligemm Mae del Castillo.
1 Chapter 4 Inheritance and Polymorphism. 2 Objectives u To develop a subclass from a superclass through inheritance. u To invoke the superclass’s constructors.
1 Exceptions. 2 Syntax Errors, Runtime Errors, and Logic Errors syntax errors, runtime errors, and logic errors You learned that there are three categories.
CSI 3125, Preliminaries, page 1 Inheritance. CSI 3125, Preliminaries, page 2 Inheritance Using inheritance, can create a general class that defines traits.
1 Chapter 8 Class Inheritance and Interfaces F Superclasses and Subclasses  Keywords: super F Overriding methods  The Object Class  Modifiers: protected,
© 2006 Pearson Addison-Wesley. All rights reserved 1-1 Chapter 1 Review of Java Fundamentals.
1 Object-Oriented Programming Inheritance. 2 Superclasses and Subclasses Superclasses and Subclasses  Superclasses and subclasses Object of one class.
Liang, Introduction to Java Programming, Tenth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 11 Inheritance and Polymorphism.
CS 112 Programming 2 Lecture 06 Inheritance & Polymorphism (1)
1 Chapter 2 Inheritance and Polymorphism. 2 Objectives u To develop a subclass from a superclass through inheritance. u To invoke the superclass’s constructors.
Terms and Rules II Professor Evan Korth New York University (All rights reserved)
Lecture10 Exception Handling Jaeki Song. Introduction Categories of errors –Compilation error The rules of language have not been followed –Runtime error.
1 Chapter 19 Multithreading. 2 Objectives F To understand the concept of multithreading and apply it to develop animation (§19.2). F To develop thread.
Chapter 13: Multithreading The Thread class The Thread class The Runnable Interface The Runnable Interface Thread States Thread States Thread Priority.
Throw, Throws & Try-Catch Statements Explanations and Pictures from: Reference:
Lecture 5:Interfaces and Abstract Classes Michael Hsu CSULA.
Garbage Collection It Is A Way To Destroy The Unused Objects. To do so, we were using free() function in C language and delete() in C++. But, in java it.
Lecture 6:Interfaces and Abstract Classes Michael Hsu CSULA.
Lecture 5:Interfaces and Abstract Classes
Multithreading / Concurrency
Chapter 13: Multithreading
Chapter 11 Inheritance and Polymorphism
Continuing Chapter 11 Inheritance and Polymorphism
Chapter 9 Inheritance and Polymorphism
Chapter 15 Multithreading
Chapter 8 Class Inheritance and Interfaces
Chapter 11 Inheritance and Polymorphism Part 2
Threads and Multithreading
Exception Handling.
Presentation transcript:

Outline §Abstract class and interface §Inner classes and initialization blocks §Equality §Exception §Threads

The abstract Modifier  The abstract class l Cannot be instantiated l Should be extended and implemented in subclasses  The abstract method l Method signature without implementation

Abstract Classes GeometricObjectCircleCylinderRectangle

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.

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.

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.

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.

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.

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];

Polymorphism Consider the code in the next page: What is the output?

public class Test { public static void main(String[] args) { m(new A());//?? m(new B());//?? m(new C());//?? m(new Object());//?? } public static void m(Object o) { System.out.println(o.toString()); } class A extends B {} class B extends C { public String toString() {return "B"; } } class C extends Object { public String toString() {return "C"; } }

public class Test { public static void main(String[] args) { m(new A());// B m(new B());//B m(new C());//C m(new } public static void m(Object o) { System.out.println(o.toString()); } class A extends B {} class B extends C { public String toString() {return "B"; } } class C extends Object { public String toString() {return "C"; } }

Polymorphism Method m (Line 9) takes a parameter of the Object type. You can invoke m with any objects (e.g. new A(), new B(), new C(), and new Object())in Lines (3-6). An object of a subclass can be used by any code designed to work with an object of its superclass. This feature is known as polymorphism (from a Greek word meaning “many forms”).

Dynamic Binding When the method m is executed, the argument x’s toString method is invoked. x may be an instance of A, B, C, or Object. Classes A, B, C, and Object have their own implementation of the toString method. Which implementation is used will be determined dynamically by the Java Virtual Machine at runtime. This capability is known as dynamic binding.

Dynamic Binding, cont. Dynamic binding works as follows: Suppose an object o is an instance of classes C 1, C 2,..., C n-1, and C n, where C 1 is a subclass of C 2, C 2 is a subclass of C 3,..., and C n-1 is a subclass of C n. That is, C n is the most general class, and C 1 is the most specific class. In Java, C n is the Object class. If o invokes a method p, the JVM searches the implementation for the method p in C 1, C 2,..., C n-1 and C n, in this order, until it is found. Once an implementation is found, the search stops and the first-found implementation is invoked.

toString() method §The toString() method returns a string representation of the object. §The default implementation returns a string consisting of a class name of which the object is an instance, the at sign and a number representing this object.

Generic Programming Polymorphism allows methods to be used generically for a wide range of object arguments. This is known as generic programming. If a method’s parameter type is a superclass, you may pass an object to this method of any of the parameter’s subclasses. When an object is used in the method, the particular implementation of the method of the object that is invoked is determined dynamically.

Note §Matching a method signature and binding a method implementation are two issues. §The compiler finds a matching method according to parameter type, number of parameters, and order of the parameters at compilation time. §A method may be implemented in several subclasses. The JVM dynamically binds the implementation of the method at runtime.

Interfaces §What Is an Interface? §Creating an Interface §Implementing an Interface

Creating an Interface modifier interface InterfaceName { constants declarations; methods signatures; }

Example of Creating an Interface // This interface is defined in // java.lang package public interface Comparable { public int compareTo(Object o); }

Generic max Method public class Max { // Return the maximum between two //objects public static Comparable max (Comparable o1, Comparable o2) { if (o1.compareTo(o2) > 0) return o1; else return o2; }

Interfaces vs. Abstract Classes In an interface, the data must be constants; an abstract class can have all types of data. Each method in an interface has only a signature without implementation; an abstract class can have concrete methods. An abstract class must contain at least one abstract method or inherit from another abstract method.

Interfaces vs. Abstract Classes, cont. Since all the methods defined in an interface are abstract methods, Java does not require you to put the abstract modifier in the methods in an interface, but you must put the abstract modifier before an abstract method in an abstract class.

Inner Classes Inner class: A class is a member of another class. Advantages: In some applications, you can use an inner class to make programs simple. §An inner class can reference the data and methods defined in the outer class in which it nests, so you do not need to pass the reference of the outer class to the constructor of the inner class.

// ShowInnerClass.java: Demonstrate using inner classes public class ShowInnerClass { private int data; // A method in the outer class public void m() { // Do something InnerClass instance = new InnerClass(); } // An inner class class InnerClass { public void mi() {// A method in the inner class // Directly reference data and method defined in its outer class data++; m(); }

Initialization Block Initialization blocks can be used to initialize objects along with the constructors. An initialization block is a block of statements enclosed inside a pair of braces. An initialization block appears within the class declaration, but not inside methods or constructors. It is executed as if it were placed at the beginning of every constructor in the class.

Initialization Block public class Book { { numOfObjects++; }

Static Initialization Block A static initialization block is much like a nonstatic initialization block except that it is declared static, can only refer to static members of the class, and is invoked when the class is loaded.

Static Initialization Block class A extends B { static { System.out.println("A's static initialization block is invoked"); } class B { static { System.out.println("B's static initialization block is invoked"); }

equals() method The equals() method compares the contents of two objects. The default implementation of the equals method in the Object class is as follows: public boolean equals(Object obj) { return (this == obj); }

== vs. equals() The == comparison operator is used for comparing two primitive data type values or for determining whether two objects have the same references. The equals method is intended to test whether two objects have the same contents, provided that the method is modified in the defining class of the objects. The == operator is stronger than the equals method, in that the == operator checks whether the two reference variables refer to the same object.

A Rectangle Class public class Rectangle { private int upperleftX, upperleftY, downrightX, downrightY; public Rectangle(int x1, int y1, int x2, int y2) { upperleftX = x1; upperleftY = y1; downrightX = x2; downrightY = y2; } public String toString() { return ”Upperleft = " + upperleftX + “,“ + upperleftY + ”; downright = " + downrightX + ”,” + downrightY; } public boolean equals(Object obj) { if(((Rectangle)obj).upperleftX == upperleftX && ((Rectangle)obj).upperleftY == upperleftY && ((Rectangle)obj).downrightX == downrightX && ((Rectangle)obj).downrightY == downrightY) return true; else return false; } public void setSize(int width, int height) { downrightX = upperleftX + width; downrightY = upperleftY + height; }

equals() example public void objectVariables(String[] args) { Rectangle rect1 = new Rectangle(5, 10, 15, 20); Rectangle rect2 = new Rectangle(5, 10, 15, 20);; System.out.println("rect1 == rect2: " + (rect1 == rect2)); //?? System.out.println("rect1.equals(rect2): " + rect1.equals(rect2)); //?? rect1 = rect2; rect2.setSize(50, 100); // (newWidth, newHeight) System.out.println("rect 1: " + rect1.toString() ); System.out.println("rect 2: " + rect2.toString() ); System.out.println("rect1 == rect2: " + (rect1 == rect2)); //?? System.out.println("rect1.equals(rect2): " + rect1.equals(rect2)); //?? int x = 12; int y = 12; System.out.println("x == y: " + (x == y) ); //?? x = 5; y = x; x = 10; System.out.println("x == y: " + (x == y) ); //?? System.out.println("x value: " + x + "\ty value: " + y); }

equals() example: result public void objectVariables(String[] args) { Rectangle rect1 = new Rectangle(5, 10, 15, 20); Rectangle rect2 = new Rectangle(5, 10, 15, 20);; System.out.println("rect1 == rect2: " + (rect1 == rect2)); //false System.out.println("rect1.equals(rect2): " + rect1.equals(rect2)); //true rect1 = rect2; rect2.setSize(50, 100); // (newWidth, newHeight) System.out.println("rect 1: " + rect1.toString() ); System.out.println("rect 2: " + rect2.toString() ); System.out.println("rect1 == rect2: " + (rect1 == rect2)); //true System.out.println("rect1.equals(rect2): " + rect1.equals(rect2)); //true int x = 12; int y = 12; System.out.println("x == y: " + (x == y) ); //true x = 5; y = x; x = 10; System.out.println("x == y: " + (x == y) ); //false System.out.println("x value: " + x + "\ty value: " + y); }

Equality versus Identity §confusion over equality and identity §identity: two things are in fact the same thing §equality: two things are for all practical purposes alike, but not the exact same thing §== versus the.equals method l use the equals method when you want to check the contents of the pointee, use == when you want to check memory addresses

How to Handle Errors? §It is possible to detect and handle errors of various types. §Problem: this complicates the code and makes it harder to understand. l the error detection and error handling code have little or nothing to do with the real code is trying to do. §A tradeoff between ensuring correct behavior under all possible circumstances and clarity of the code

Exceptions §Many languages, including Java use a mechanism know as Exceptions to handle errors at runtime l In Java Exception is a class with many descendants. l ArrayIndexOutOfBoundsException l NullPointerException l FileNotFoundException l ArithmeticException l IllegalArgumentException

Unchecked Exceptions §Exceptions in Java fall into two different categories l checked and unchecked §unchecked exceptions are completely preventable and should never occur. (They are caused by logic errors, created by us, the programmers.) l Descendents of the RuntimeException class l Examples: ArrayIndexOutOfBoundsException, NullPointerException, ArithmeticException l There does not need to be special error handling code l If error handling code was required programs would be unwieldy because so many Java statements have the possibility of generating or causing an unchecked Exception

Checked Exceptions §Checked exceptions represent conditions that, although exceptional, can reasonably be expected to occur, and if they do occur must be dealt with in some way (other than the program terminating). §Unchecked exceptions are due to a programming logic error, your fault and preventable if coded correctly §Checked exceptions represent errors that are unpreventable by you!

try-catch Format try { code that might throw an exception; } catch (exception_type_1 e) { code to handle exception of type 1; }... catch (exception_type_n e) { code to handle exception of type n; } code that can cause an unchecked exception does not need to be placed in a try-catch block, but if an unchecked exception occurs and is not caught the program will stop

Dealing with exceptions §if a method has code that could generate a checked exception it must either l deal with it or l declare it can throw an exception of the type (passes the problem onto the methods that call it) public void method1() {try {method2(); } catch(ExceptionType1 e) {doErrorProcessing; } public void method2() throws ExceptionType1 {methodThatThrowsExceptionType1;}

When an Exception Occurs §If an exception occurs flow of control is shifted out of the try block or method where it occurred §The skipped code is not executed  a finally clause or block can be included after a try catch block.  Code in the finally clause is always executed after the execution in the try block ends (by normal completion or because of an exception) §code in the finally block always executes before searching for catch blocks to handle an exception §used to clean up resources

Example public boolean searchFor(String file, String word) throws StreamException {Stream input = null; try {input = new Stream(file); while(!input.eof()) {if(input.next().equals(word)) return true; } // word not found in file return false; } finally {if(input != null) input.close(); }

Threads Concept Multiple threads on multiple CPUs Multiple threads sharing a single CPU

Creating Threads by Extending the Thread class

Using the Thread Class to Create and Launch Threads §Objective: Create and run three threads: l The first thread prints the letter a 100 times. l The second thread prints the letter b 100 times. l The third thread prints the integers 1 through 100.

Example 1: Using the Thread Class to Create and Launch Threads, cont. TestThread Run

Creating Threads by Implementing the Runnable Interface

Example 2: Using the Runnable Interface to Create and Launch Threads §Objective: Create and run three threads: l The first thread prints the letter a 100 times. l The second thread prints the letter b 100 times. l The third thread prints the integers 1 through 100. TestRunnable Run

Controlling Threads and Thread States §void run() Invoked by the Java runtime system to execute the thread. You must override this method and provide the code you want your thread to execute. §void start() Starts the thread, which causes the run() method to be invoked. Called by the runnable object in the client class. §static void sleep(long millis) throws InterruptedException Puts the runnable object to sleep for a specified time in milliseconds.

Controlling Threads and Thread States, cont. §void stop() Stops the thread. (deprecated in JDK 1.2)  void suspend() (deprecated in JDK 1.2) Suspends the thread. Use the resume() method to resume.  void resume() (deprecated in JDK 1.2) Resumes the thread suspended with the suspend() method.

Thread Priority  Each thread is assigned a default priority of Thread.NORM_PRIORITY. You can reset the priority using setPriority(int priority).  Some constants for priorities include Thread.MIN_PRIORITY Thread.MAX_PRIORITY Thread.NORM_PRIORITY

Thread States

Thread Groups  Construct a thread group using the ThreadGroup constructor: ThreadGroup g = new ThreadGroup("timer thread group");  Place a thread in a thread group using the Thread constructor: Thread t = new Thread(g, new ThreadClass(), "This thread");

Thread Groups, cont.  To find out how many threads in a group are currently running, use the activeCount() method: System.out.println("The number of “ + “ runnable threads in the group ” + g.activeCount());

Synchronization A shared resource may be corrupted if it is accessed simultaneously by multiple threads. For example, two unsynchronized threads accessing the same bank account causes conflict.

Example 3: Showing Resource Conflict §Objective: create and launch 100 threads, each of which adds a penny to a piggy bank. Assume that the piggy bank is initially empty.

Example 3, cont PiggyBankWithoutSyncRun... }

Creating a Thread to run the while loop, cont. public void run() { while (true) { repaint(); try { thread.sleep(1000); waitForNotificationToResume(); } catch (InterruptedException ex) { }

Creating a Thread to run the while loop, cont. private synchronized void waitForNotificationToResume() throws InterruptedException { while (suspended) wait(); }

Creating a Thread to run the while loop, cont. public synchronized void resume() { if (suspended) { suspended = false; notify(); } public synchronized void suspend() { suspended = true; }

Example 4: Displaying a Running Clock in in an Applet Objective: Simulate a running clock by using a separate thread to repaint the clock. ClockAppletRun Applet Viewer