1 / 29

Handling Errors

Learn how to handle errors and exceptions in Java programming efficiently using try-catch blocks and streams for improved error management and code reliability.

Download Presentation

Handling Errors

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Handling Errors • What happens if someone attempts to add an item to a queue that is full? • Many times it is the client that knows what the appropriate thing to do is in the case of an error. • Exceptions provide a method of informing a client that an error has occurred and provides a mechanism for handling the error cleanly. • Many languages provide support for exceptions. Exceptions and Streams

  2. Java Exception Handling • An exception occurs, thrown, when something goes wrong while a program is running. • If an exception is not handled, caught, the program will terminate. • When an exception is thrown, the exception is passed to the caller of the method. • The caller can then handle the exception or allow it to propagate back up the call chain. Exceptions and Streams

  3. Java Exceptions • An exception object stores information about the cause of an exception. Exceptions must be a subclass of Throwable • Throwable and its subclasses have two constructors, one that takes no arguments, and one that takes a String argument that can be used to produce an error message • A Throwable class contains a snapshot of the state of the program at the time it was created • It can also contain a message string that gives more information about the error Exceptions and Streams

  4. Exception Class Hierarchy indicates serious problems that a reasonable application should not try to catch. Most such errors are abnormal conditions Object these exceptions must be explicitly dealt with Throwable Exception Error other classes ... other classes ... RunTimeException These exceptions do not need to be caught or declared in throws clause other classes ... Exceptions and Streams

  5. ActivationException ApplicationException AWTException ClassNotFoundException, DataFormatException GeneralSecurityException IllegalAccessException InstantiationException InterruptedException IOException NoSuchMethodException ParseException ArithmeticException ArrayIndexOutOfBoundsException ArrayStoreException ClassCastException ClassNotFoundException IllegalAccessException IllegalArgumentException IndexOutOfBoundsException NegativeArraySizeException NullPointerException NumberFormatException ... Java Exceptions (partial list) Exceptions and Streams

  6. What Exceptions are Thrown? • How do you figure out what exception will be thrown that you must handle? • read the documentation for the class you are using • read the documentation about the various exception classes • I often simply use the methods I want and let the compiler tell me when I missed something!! Exceptions and Streams

  7. Try, Catch, and Finally • A try block is wrapped around code that may cause an exception. • catch blocks following the try block can contain code to deal with the exception. • A finally block contains code that will be executed whether or not an exception occurs. • In most cases try and catch blocks suffice Exceptions and Streams

  8. Syntax try { statementSequence } catch ( parameter ) { statementSequence } finally { statementSequence } Exceptions and Streams

  9. CmdLine public class CmdLine { public static void main( String args[] ) { for ( int i=0; i<args.length; i++ ) { int val; try { val = Integer.parseInt( args[i] ); System.out.println( val ); } catch ( NumberFormatException e ) { System.out.println( "??" ); } } } } Exceptions and Streams

  10. Java Exception Handling • An exception occurs, thrown, when something goes wrong while a program is running. • If an exception is not handled, caught, the program will terminate. • When an exception is thrown, the exception is passed to the caller of the method. • The caller can then handle the exception or allow it to propagate back up the call chain. Exceptions and Streams

  11. throws • If a method wishes to pass an exception to a caller, the exception must be listed in the throws clause of the method • public int aMethod() throws NumberFormatException • If a method does something that may cause an exception to be thrown • the exception must be caught • or the exception must be listed in the method’s throw clause Exceptions and Streams

  12. Streams • Java provides many stream classes that let you work with data in the forms that you usually use rather than at the low, byte level. • These are implemented in the abstract classes InputStream and Outputstream. • The methods in these classes provide the ability to do simple, byte oriented operations. Exceptions and Streams

  13. Streams • To receive information, a program opens a stream and reads the information: • A program can send information by opening a stream to a destination and writes the information: Exceptions and Streams

  14. Using Streams • No matter where the information is coming from or going to and no matter what type of data is being read or written, the algorithms for reading and writing data is pretty much always the same Reading open a stream while more information read information close the stream Writing open a stream while more information write information close the stream Exceptions and Streams

  15. java.io.* • The java.io package contains a collection of stream classes that support reading/writing from/to streams • Streams are divided into two class hierarchies based on the type of data on which they operate. Exceptions and Streams

  16. InputStream Classes InputStream ByteArray InputStream File InputStream Filter InputStream Piped InputStream Sequence InputStream StringBuffer InputStream Object InputStream Buffered InputStream Checked InputStream Data InputStream Digest InputStream Inflator InputStream ProgressMonitor InputStream PushBack InputStream GZip InputStream Zip InputStream Exceptions and Streams

  17. Data Sink Streams Exceptions and Streams

  18. Data Processing Streams Exceptions and Streams

  19. Streams and Files • Data files are handled using two abstractions: • the basic file abstraction is provided by the library class File. This encapsulates all the details of what a file is and how it is named. • The stream abstraction provides a way of reading and writing data to and from a file. • Reader streams deal with text input and are subclasses of Reader, writer streams perform text output and are subclasses of Writer. Exceptions and Streams

  20. BufferedReader • A BufferedReader reads text from a character-input stream, buffering characters so as to provide for the efficient reading of characters, arrays, and lines. • The buffer size may be specified, or the default size may be used. • A BufferedReader is usually wrapped around any Reader whose read() operations may be costly. Exceptions and Streams

  21. FileEcho import java.io.*; public class FileEcho { public static void main( String args[] ) { if ( args.length>0 ) { BufferedReader in = null; try { in = new BufferedReader( new FileReader( args[0] ) ); while ( in.ready() ) { char ch = (char)in.read(); System.out.print( ch ); } } catch ( FileNotFoundException e ) { System.out.println( "File not found" ); } catch( IOException e ) { System.out.println( "Read error" ); System.exit(1); }}}} Exceptions and Streams

  22. InputEcho import java.io.*; public class InputEcho { public static void main( String args[] ) { // Set things up to read from the keyboard BufferedReader keyboard = new BufferedReader( new InputStreamReader( System.in ) ); // Read stuff form input and dump to output try { String inString; while ( ( inString = keyboard.readLine() ) != null ) { System.out.println( inString ); } } catch ( IOException e ) { System.err.println( "InputEcho: I/O error" ); System.exit( 1 ); } } } Exceptions and Streams

  23. ReadNums import java.util.*; import java.io.*; public class ReadNums { public static void main( String args[] ) { // Make sure the number of arguments is correct if ( args.length != 1 ) { System.err.println( "Usage: ReadNums sourceFile" ); System.exit(1); } // Initialize src since the assignment is done inside a try block BufferedReader src = null; // Attempt to open the file for reading try { src = new BufferedReader( new FileReader( args[0] ) ); } catch ( FileNotFoundException e ) { System.err.println( "ReadNums: Unable to open source file" ); System.exit(1); } Exceptions and Streams

  24. ReadNums (continued) // Read the numbers a line at a time from the source file Vector data = new Vector(); try { String line; while ( ( line = src.readLine() ) != null ) { try { int num = Integer.parseInt( line ); data.addElement( new Integer( num ) ); } catch ( NumberFormatException e ) {} } src.close(); } catch ( IOException e ) { System.err.println( "ReadNums: " + e.getMessage() ); System.exit(1); } // Print out the results for ( int i=0; i<data.size(); i++ ) System.out.println( data.elementAt( i ) ); }} Exceptions and Streams

  25. InputStreamReader • An InputStreamReaderis a bridge from byte streams to character streams: it reads bytes and translates them into characters according to a specified character encoding. • Each invocation of one of an InputStreamReader's read() methods may cause one or more bytes to be read from the underlying byte-input stream. Exceptions and Streams

  26. PrintWriter • A PrintWriter prints formatted representations of objects to a text-output stream. • Flushing does not occur until the flush() method is invoked. It is possible to enable automatic flushing, which causes a flush to take place after any println() method is invoked. The output of a newline character does not cause a flush. • Methods in this class never throw I/O exceptions. Exceptions and Streams

  27. Building a Simple Expression Evaluator • Consider building an expression evaluator for the following: • identifiernumber; • identifier ; • The code to do this follows. It uses the following classes: • InputStreamReader • StreamTokenizer • HashTable Exceptions and Streams

  28. ExprEval import java.io.*; import java.util.*; public class ExprEval { public static void main( String args[] ) { StreamTokenizer lex = new StreamTokenizer( new InputStreamReader( System.in ) ); final int WANT_WORD = 0; final int WANT_NUM = 1; final int WANT_SEMI = 2; int curState = WANT_WORD; String curId = null; Hashtable symTbl = new Hashtable(); lex.ordinaryChar( '-' ); // '-' is treated normally lex.lowerCaseMode( true ); // make case insensitive Exceptions and Streams

  29. ExprEval try { while ( lex.nextToken() != StreamTokenizer.TT_EOF ) { switch ( lex.ttype ) { case lex.TT_WORD: if ( curState == WANT_WORD ) { curId = lex.sval; curState = WANT_NUM; } else curState = WANT_SEMI; break; case lex.TT_NUMBER: if ( curState == WANT_NUM ) symTbl.put( curId, new Integer( (int)lex.nval) ); curState = WANT_SEMI; break; case ';': if ( curState == WANT_NUM ) System.out.println( symTbl.get( curId ) ); curState = WANT_WORD; break; default: curState = WANT_SEMI; }}} catch( Exception e ) { System.out.println( "I/O Error" ); }}} Exceptions and Streams

More Related