D06 PROGRAMMING with JAVA



Similar documents
D06 PROGRAMMING with JAVA

D06 PROGRAMMING with JAVA. Ch3 Implementing Classes

CS 111 Classes I 1. Software Organization View to this point:

Lecture J - Exceptions

JAVA - EXCEPTIONS. An exception can occur for many different reasons, below given are some scenarios where exception occurs.

Designing with Exceptions. CSE219, Computer Science III Stony Brook University

Chapter 20 Streams and Binary Input/Output. Big Java Early Objects by Cay Horstmann Copyright 2014 by John Wiley & Sons. All rights reserved.

D06 PROGRAMMING with JAVA

I. INTRODUCTION. International Journal of Computer Science Trends and Technology (IJCST) Volume 3 Issue 2, Mar-Apr 2015

java.util.scanner Here are some of the many features of Scanner objects. Some Features of java.util.scanner

Scanner. It takes input and splits it into a sequence of tokens. A token is a group of characters which form some unit.

CSE 1223: Introduction to Computer Programming in Java Chapter 7 File I/O

Exception Handling. Overloaded methods Interfaces Inheritance hierarchies Constructors. OOP: Exception Handling 1

CSE 1223: Introduction to Computer Programming in Java Chapter 2 Java Fundamentals

Using Files as Input/Output in Java 5.0 Applications

AP Computer Science Static Methods, Strings, User Input

J a v a Quiz (Unit 3, Test 0 Practice)

public static void main(string[] args) { System.out.println("hello, world"); } }

Reading Input From A File

File class in Java. Scanner reminder. Files 10/19/2012. File Input and Output (Savitch, Chapter 10)

Software Construction

Programming by Contract. Programming by Contract: Motivation. Programming by Contract: Preconditions and Postconditions

D06 PROGRAMMING with JAVA

Part I. Multiple Choice Questions (2 points each):

CS506 Web Design and Development Solved Online Quiz No. 01

Java Interview Questions and Answers

First Java Programs. V. Paúl Pauca. CSC 111D Fall, Department of Computer Science Wake Forest University. Introduction to Computer Science

Introduction to Java

public static void main(string args[]) { System.out.println( "f(0)=" + f(0));

Java Programming Language

Translating to Java. Translation. Input. Many Level Translations. read, get, input, ask, request. Requirements Design Algorithm Java Machine Language

No no-argument constructor. No default constructor found

Masters programmes in Computer Science and Information Systems. Object-Oriented Design and Programming. Sample module entry test xxth December 2013

Question R11.3. R11.3 How do you open a file whose name contains a backslash, like c:\temp\output.dat?

CS 121 Intro to Programming:Java - Lecture 11 Announcements

CS 141: Introduction to (Java) Programming: Exam 1 Jenny Orr Willamette University Fall 2013

Creating a Simple, Multithreaded Chat System with Java

AP Computer Science File Input with Scanner

Moving from CS 61A Scheme to CS 61B Java

AP Computer Science Java Subset

Handout 1. Introduction to Java programming language. Java primitive types and operations. Reading keyboard Input using class Scanner.

D06 PROGRAMMING with JAVA

13 File Output and Input

Chapter 13 - Inheritance

CompSci 125 Lecture 08. Chapter 5: Conditional Statements Chapter 4: return Statement

Introduction to Java Applications Pearson Education, Inc. All rights reserved.

D06 PROGRAMMING with JAVA

Explain the relationship between a class and an object. Which is general and which is specific?

Object-Oriented Design Lecture 4 CSU 370 Fall 2007 (Pucella) Tuesday, Sep 18, 2007

1) Which of the following is a constant, according to Java naming conventions? a. PI b. Test c. x d. radius

Course Intro Instructor Intro Java Intro, Continued

Java from a C perspective. Plan

Preet raj Core Java and Databases CS4PR. Time Allotted: 3 Hours. Final Exam: Total Possible Points 75

Licensed for viewing only. Printing is prohibited. For hard copies, please purchase from

C++ INTERVIEW QUESTIONS

MULTIPLE CHOICE. Choose the one alternative that best completes the statement or answers the question.

Chulalongkorn University International School of Engineering Department of Computer Engineering Computer Programming Lab.

The Java Series. Java Essentials I What is Java? Basic Language Constructs. Java Essentials I. What is Java?. Basic Language Constructs Slide 1

LOOPS CHAPTER CHAPTER GOALS

Chapter 2 Introduction to Java programming

Event-Driven Programming

Sample CSE8A midterm Multiple Choice (circle one)

Chapter 10. A stream is an object that enables the flow of data between a program and some I/O device or file. File I/O

Chapter 3. Input and output. 3.1 The System class

Master of Sciences in Informatics Engineering Programming Paradigms 2005/2006. Final Examination. January 24 th, 2006

Understanding class definitions

WRITING DATA TO A BINARY FILE

Chapter 2. println Versus print. Formatting Output withprintf. System.out.println for console output. console output. Console Input and Output

3 Improving the Crab more sophisticated programming

Building Java Programs

IRA EXAMPLES. This topic has two examples showing the calculation of the future value an IRA (Individual Retirement Account).

ICOM 4015: Advanced Programming

Arrays. Introduction. Chapter 7

The Interface Concept

AP Computer Science Java Mr. Clausen Program 9A, 9B

Building a Multi-Threaded Web Server

Software Development in Java

Teach Yourself Java in 21 Minutes

1 Description of The Simpletron

Object-Oriented Programming in Java

qwertyuiopasdfghjklzxcvbnmqwerty uiopasdfghjklzxcvbnmqwertyuiopasd fghjklzxcvbnmqwertyuiopasdfghjklzx cvbnmqwertyuiopasdfghjklzxcvbnmq

Programming Languages CIS 443

System.out.println("\nEnter Product Number 1-5 (0 to stop and view summary) :

Arrays in Java. Working with Arrays

Install Java Development Kit (JDK) 1.8

Introduction to Java. CS 3: Computer Programming in Java

WA2099 Introduction to Java using RAD 8.0 EVALUATION ONLY. Student Labs. Web Age Solutions Inc.

Form Validation. Server-side Web Development and Programming. What to Validate. Error Prevention. Lecture 7: Input Validation and Error Handling

CS193j, Stanford Handout #10 OOP 3

Manual For Using the NetBeans IDE

Classes and Objects in Java Constructors. In creating objects of the type Fraction, we have used statements similar to the following:

Building Java Programs

6.1. Example: A Tip Calculator 6-1

16.1 DataFlavor DataFlavor Methods. Variables

TABLE OF CONTENTS...2 INTRODUCTION...3 APPLETS AND APPLICATIONS...3 JAVABEANS...4 EXCEPTION HANDLING...5 JAVA DATABASE CONNECTIVITY (JDBC)...

Software Testing. Definition: Testing is a process of executing a program with data, with the sole intention of finding errors in the program.

Chapter 2: Elements of Java

Transcription:

Cicles Formatius de Grau Superior Desenvolupament d Aplicacions Informàtiques D06 PROGRAMMING with JAVA Ch15 Exception Handling PowerPoint presentation, created by Angel A. Juan - ajuanp(@)gmail.com, for accompanying the book Big Java, by Cay S. Horstmann (2006)

Chapter Goals To learn how to throw exceptions To be able to design your own exception classes To understand the difference between checked and unchecked exceptions To learn how to catch exceptions To know when and where to catch an exception

Error Handling What should a method do when it detects an error condition? Traditional approach: The method returns a value that indicates whether it succeed or failed (error code) Problem 1: The calling method may forget to check the return value A failure notification may go completely undetected the program keeps processing faulty information and mysteriously failing later Problem 2: The calling method may not be able to do anything about the failure The calling method must fail too and let its caller worry about it many method calls would need to be checked for failure: x.dosomething() if (!x.dosomething()) return false; The exception handling mechanism solves these two problems: Exceptions can t be overlooked Exceptions are sent directly to an exception handler not just the caller of the failed method

Throwing Exceptions When you detect an error condition, you just throw an appropriate exception object The Java library provides many classes to signal all sorts of exceptional conditions (Fig. 1) Figure 1: The Hierarchy of Exception Classes Checked exceptions Unchecked exceptions Continued

Throwing Exceptions Example: public class BankAccount public void withdraw(double amount) if (amount > balance) IllegalArgumentException exception = new IllegalArgumentException("Amount exceeds balance"); throw exception; balance = balance - amount;... You don t have to store the exception object in a variable. You can just throw the object that the new operator returns: throw new IllegalArgumentException("Amount exceeds balance"); When you throw an exception, execution does not continue with the next statement but with an exception handler (we ll see later)

Syntax 15.1: Throwing an Exception throw exceptionobject; Example: throw new IllegalArgumentException(); Purpose: To throw an exception and transfer control to a handler for this exception type

Self Check 1. How should you modify the deposit method to ensure that the balance is never negative? 2. Suppose you construct a new bank account object with a zero balance and then call withdraw(10). What is the value of balance afterwards?

Answers 1. Throw an exception if the amount being deposited is less than zero. 2. The balance is still zero because the last statement of the withdraw method was never executed.

Checked and Unchecked Exceptions Java exceptions fall into two categories, called checked (due to external circumstances that the programmer cannot prevent) and unchecked exceptions (due to programming errors) When you call a method that throws a checked exception The compiler checks that you don't ignore it You must tell the compiler what you are going to do about the exception if it is ever thrown E.g.: all subclasses of IOException are unchecked exceptions When you call a method that throws an unchecked exception The compiler does not require you to keep track of unchecked exceptions Exceptions, such as NumberFormatException, IllegalArgumentException, and NullPointerException, are unchecked exceptions. More generally, all exceptions that belong to subclasses of RuntimeException are unchecked, and all other subclasses of the class Exception are checked Continued

Checked and Unchecked Exceptions There is a second category of internal errors that are reported by throwing objects of type Error (e.g.: OutOfMemoryError, which is thrown when all available memory has been used up). These are fatal errors that happen rarely and are beyond your control. They are too unchecked Why have two kinds of exceptions? A checked exception describes a problem that is likely to occur at times, no matter how careful you are (e.g.: an unexpected end of file due to a disk error or a broken network connection). The compiler does insist that your program be able to handle error conditions that you cannot prevent. The majority of checked exceptions occur when you deal with input and output (i.e.: when programming with files and streams) The unchecked exceptions are your fault (e.g.: a NullPointerException your code was wrong when it tried to use a null reference; the compiler doesn t check whether you handle a NullPointerException, because you should test your references for null before using them rather than install a handler for that exception) Continued

Checked and Unchecked Exceptions Example (checked): You can use the Scanner class to read data from a file, by passing a FileReader object to the Scanner constructor: String filename =...; FileReader reader = new FileReader(filename); Scanner in = new Scanner(reader); However, the FileReader constructor can throw a FileNotFoundException, which is a checked exception, so you need to tell the compiler what you are going to do about it. You have two choices: You can handle the exception (we ll see how to do that), or You can tell the compiler that you are aware of this exception and that you want your method to be terminated when it occurs. To do this, tag the method with a throws specifier. The throws clause signals the caller of your method that it may encounter a FileNotFoundException (then the caller needs to make the same decision handle the exception, or tell its caller that the exception may be thrown): public void read(string filename) throws FileNotFoundException FileReader reader = new FileReader(filename); Scanner in = new Scanner(reader);... Continued

Checked and Unchecked Exceptions If your method can throw checked exceptions of different types, you separate the class names by commas: public void read(string filename) throws IOException, ClassNotFoundException Always keep in mind that exception classes form an inheritance hierarchy. For example, FileNotFoundException is a subclass of IOException. Thus if a method can throw both of them, you only tag it as throws IOException It sounds somehow irresponsible not to handle an exception when you know that it happened. Actually, though, it is usually best not to catch an exception if you don t know how to remedy the situation

Syntax 15.2: Exception Specification accessspecifier returntype methodname(parametertype parametername,...) throws ExceptionClass, ExceptionClass,... Example: public void read(bufferedreader in) throws IOException Purpose: To indicate the checked exceptions that this method can throw

Self Check 3. Suppose a method calls the FileReader constructor and the read method of the FileReader class, which can throw an IOException. Which throws specification should you use? 4. Why is a NullPointerException not a checked exception?

Answer 3. The specification throws IOException is sufficient because FileNotFoundException is a subclass of IOException. 4. Because programmers should simply check for null pointers instead of trying to handle a NullPointerException.

Catching Exceptions Every exception should be handled somewhere in your program. If an exception has no handler, an error message is printed, and your program terminates you should install exception handlers for all exceptions that your program might throw You install an exception handler with the try/catch statement. Each try block contains one or more statements that may cause an exception. Each catch clause contains the handler for an exception type: try String filename =...; FileReader reader = new FileReader(filename); Scanner in = new Scanner(reader); String input = in.next(); int value = Integer.parseInt(input);... catch (IOException exception) exception.printstacktrace(); catch (NumberFormatException exception) System.out.println("Input was not a number"); Continued

Catching Exceptions Three exceptions may be thrown in the former try block: The FileReader constructor can throw a FileNotFoundException, Scanner.next can throw a NoSuchElementException, and Integer.parseInt can throw a NumberFormatException. If any of these exceptions is actually thrown, then the rest of the instructions of the try block are skipped Here is what happens for the various exception types: If a FileNotFoundException is thrown, then the catch clause for the IOException is excecuted (since FileNotFoundException is a subclass of IOException) If a NumberFormatException occurs, then the second catch clause is executed A NoSuchElementException is not caught by any of the catch clauses. The exception remains thrown until it is caught by another try block When the catch (IOException exception) block is executed, then some method in the try block has failed with an IOException. The variable exception contains a reference to the exception object that was thrown. The catch clause can analyze that object to find out more details about the failure (e.g.: you can get a printout of the chain of method calls that lead to the exception, by calling exception.printstacktrace())

Throw Early, Catch Late When a method notices a problem that it cannot solve, it is generally better to throw an exception rather than try to come up with an imperfect fix Conversely, a method should only catch an exception if it can really remedy the situation. Otherwise, the best remedy is simply to have the exception propagate to its caller, allowing it to be caught by a competent handler Remember: Throw early, catch late

Continued Syntax 15.3: General Try Block try statement statement... catch (ExceptionClass exceptionobject) statement statement... catch (ExceptionClass exceptionobject) statement statement......

Syntax 15.3: General Try Block Example: try System.out.println("How old are you?"); int age = in.nextint(); System.out.println("Next year, you'll be " + (age + 1)); catch (InputMismatchException exception) exception.printstacktrace(); Purpose: To execute one or more statements that may generate exceptions. If an exception occurs and it matches one of the catch clauses, execute the first one that matches. If no exception occurs, or an exception is thrown that doesn't match any catch clause, then skip the catch clauses.

Self Check 5. Suppose the file with the given file name exists and has no contents. Trace the flow of execution in the try block in this section. 6. Is there a difference between catching checked and unchecked exceptions?

Answers 5. The FileReader constructor succeeds, and in is constructed. Then the call in.next() throws a NoSuchElementException, and the try block is aborted. None of the catch clauses match, so none are executed. If none of the enclosing method calls catch the exception, the program terminates. 6. No you catch both exception types in the same way, as you can see from the code example on page 558. Recall that IOException is a checked exception and NumberFormatException is an unchecked exception.

Continued The finally Clause Occasionally, you need to take some action whether or not an exception is thrown. The finally construct is used to handle this situation Example: a program can only open a finite number of files at one time you need to close all file readers after you are done with them: reader = new FileReader(filename); Scanner in = new Scanner(reader); readdata(in); reader.close(); // May never get here Suppose that one of the methods before the last line throws an exception the call to close is never executed! Solve this problem by placing the call to close inside a finally clause:

Continued The finally Clause FileReader reader = new FileReader(filename); try Scanner in = new Scanner(reader); readdata(in); finally reader.close(); // if an exception occurs, finally clause // is also executed before exception is // passed to its handler In a normal case, there will no problem: when the try block is completed, the finally clause is executed, and the file is closed. However, if an exception occurs, the finally clause is also executed before the exception is passed to its handler Use the finally clause whenever you need to do some clean up, such as closing a file, to ensure that the clean up happens no matter how the method exits

The finally Clause It is tempting to combine catch and finally clauses, but the resulting code can be hard to understand. Instead, use a try/finally statement to close resources and a separate try/catch to handle errors: try FileReader reader = new FileReader(filename); try // Read input finally reader.close(); catch (IOException exception) // Handle exception

Continued Syntax 15.4: The finally clause try statement statement... finally statement statement...

Syntax 15.4: The finally clause Example: FileReader reader = new FileReader(filename); try readdata(reader); finally reader.close(); Purpose: To ensure that the statements in the finally clause are executed whether or not the statements in the try block throw an exception.

Self Check 7. Why was the reader variable declared outside the try block? 8. Suppose the file with the given name does not exist. Trace the flow of execution of the code segment in this section.

Answers 7. If it had been declared inside the try block, its scope would only have extended to the end of the try block, and the catch clause could not have closed it. 8. The FileReader constructor throws an exception. The finally clause is executed. Since reader is null, the call to close is not executed. Next, a catch clause that matches the FileNotFoundException is located. If none exists, the program terminates.

Designing Your Own Execution Types You can design your own exception types subclasses of Exception or RuntimeException: if (amount > balance) throw new InsufficientFundsException( "withdrawal of " + amount + " exceeds balance of + balance); public class InsufficientFundsException extends RuntimeException public InsufficientFundsException() Supply two constructors Default constructor public InsufficientFundsException(String message) super(message); A constructor that accepts a message string describing reason for exception Make it an unchecked exception programmer could have avoided it by calling getbalance first

Self Check 9. What is the purpose of the call super(message) in the second InsufficientFundsException constructor? 10. Suppose you read bank account data from a file. Contrary to your expectation, the next input value is not of type double. You decide to implement a BadDataException. Which exception class should you extend?

Answers 9. To pass the exception message string to the RuntimeException superclass. 10. Exception or IOException are both good choices. Because file corruption is beyond the control of the programmer, this should be a checked exception, so it would be wrong to extend RuntimeException.

A Complete Program Program Asks user for name of file File expected to contain data values First line of file contains total number of values Remaining lines contain the data Typical input file: 3 1.45-2.1 0.05 What can go wrong? File might not exist File might have data in wrong format Who can detect the faults? FileReader constructor will throw an exception when file does not exist Methods that process input need to throw exception if they find error in data format

A Complete Program What exceptions can be thrown? FileNotFoundException can be thrown by FileReader constructor IOException can be thrown by close method of FileReader BadDataException, a custom checked exception class Who can remedy the faults that the exceptions report? Only the main method of DataSetTester program interacts with user Catches exceptions Prints appropriate error messages Gives user another chance to enter a correct file

File DataSetTester.java 01: import java.io.filenotfoundexception; 02: import java.io.ioexception; 03: import java.util.scanner; 04: 05: public class DataSetTester 06: 07: public static void main(string[] args) 08: 09: Scanner in = new Scanner(System.in); 10: DataSetReader reader = new DataSetReader(); 11: 12: boolean done = false; 13: while (!done) 14: 15: try 16: Continued

Continued File DataSetTester.java 17: System.out.println("Please enter the file name: "); 18: String filename = in.next(); 19: 20: double[] data = reader.readfile(filename); 21: double sum = 0; 22: for (double d : data) sum = sum + d; 23: System.out.println("The sum is " + sum); 24: done = true; 25: 26: catch (FileNotFoundException exception) 27: 28: System.out.println("File not found."); 29: 30: catch (BadDataException exception) 31: 32: System.out.println ("Bad data: " + exception.getmessage());

File DataSetTester.java 33: 34: catch (IOException exception) 35: 36: exception.printstacktrace(); 37: 38: 39: 40:

The readfile method of the DataSetReader class Constructs Scanner object Calls readdata method Completely unconcerned with any exceptions (if there is a problem with the input file, it simply passes the exception to the caller) public double[] readfile(string filename) throws IOException, BadDataException // FileNotFoundException is an IOException FileReader reader = new FileReader(filename); try Scanner in = new Scanner(reader); readdata(in); finally reader.close(); return data;

The readdata method of the DataSetReader class Reads the number of values Constructs an array Calls readvalue for each data value private void readvalue(scanner in, int i) throws BadDataException if (!in.hasnextdouble()) throw new BadDataException("Data value expected"); data[i] = in.nextdouble(); private void readdata(scanner in) throws BadDataException if (!in.hasnextint()) throw new BadDataException("Length expected"); int numberofvalues = in.nextint(); data = new double[numberofvalues]; for (int i = 0; i < numberofvalues; i++) readvalue(in, i); if (in.hasnext()) throw new BadDataException("End of file expected"); Checks for two potential errors: File might not start with an integer File might have additional data after reading all values Makes no attempt to catch any exceptions

Scenario 1. DataSetTester.main calls DataSetReader.readFile 2. readfile calls readdata 3. readdata calls readvalue 4. readvalue doesn't find expected value and throws BadDataException 5. readvalue has no handler for exception and terminates 6. readdata has no handler for exception and terminates 7. readfile has no handler for exception and terminates after executing finally clause 8. DataSetTester.main has handler for BadDataException; handler prints a message, and user is given another chance to enter file name

File DataSetReader.java 01: import java.io.filereader; 02: import java.io.ioexception; 03: import java.util.scanner; 04: 05: /** 06: Reads a data set from a file. The file must have // the format 07: numberofvalues 08: value1 09: value2 10:... 11: */ 12: public class DataSetReader 13: Continued

Continued File DataSetReader.java 14: /** 15: Reads a data set. 16: @param filename the name of the file holding the data 17: @return the data in the file 18: */ 19: public double[] readfile(string filename) 20: throws IOException, BadDataException 21: 22: FileReader reader = new FileReader(filename); 23: try 24: 25: Scanner in = new Scanner(reader); 26: readdata(in); 27: 28: finally 29: 30: reader.close(); 31:

File DataSetReader.java 32: return data; 33: 34: 35: /** 36: Reads all data. 37: @param in the scanner that scans the data 38: */ 39: private void readdata(scanner in) throws BadDataException 40: 41: if (!in.hasnextint()) 42: throw new BadDataException("Length expected"); 43: int numberofvalues = in.nextint(); 44: data = new double[numberofvalues]; 45: 46: for (int i = 0; i < numberofvalues; i++) 47: readvalue(in, i); Continued

File DataSetReader.java 48: 49: if (in.hasnext()) 50: throw new BadDataException("End of file expected"); 51: 52: 53: /** 54: Reads one data value. 55: @param in the scanner that scans the data 56: @param i the position of the value to read 57: */ 58: private void readvalue(scanner in, int i) throws BadDataException 59: 60: if (!in.hasnextdouble()) 61: throw new BadDataException("Data value expected"); 62: data[i] = in.nextdouble(); 63: 64: 65: private double[] data; 66:

Self Check 11. Why doesn't the DataSetReader.readFile method catch any exceptions? 12. Suppose the user specifies a file that exists and is empty. Trace the flow of execution.

Answers 11. It would not be able to do much with them. The DataSetReader class is a reusable class that may be used for systems with different languages and different user interfaces. Thus, it cannot engage in a dialog with the program user 12. DataSetTester.main calls DataSetReader.readFile, which calls readdata. The call in.hasnextint() returns false, and readdata throws a BadDataException. The readfile method doesn't catch it, so it propagates back to main, where it is caught

Chapter Summary To signal an exceptional condition, use the throw statement to throw an exception object When you throw an exception, the current method terminates immediately There are two kinds of exceptions: checked and unchecked. Unchecked exceptions extend the class RuntimeException or Error Checked exceptions are due to external circumstances that the programmer cannot prevent. The compiler checks that your program handles these exceptions In a method that is ready to handle a particular exception type, place the statements that can cause the exception inside a try block, and the handler inside a catch clause Continued

Chapter Summary It is better to declare that a method throws a checked exception that to handle the exception poorly Once a try block is entered, the statements in a finally clause are guaranteed to be executed, whether or not an exception is thrown You can design your own exception types subclasses of Exception or RuntimeException