CS 46B: Introduction to Data Structures June 9 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak www.cs.sjsu.edu/~mak.

Slides:



Advertisements
Similar presentations
AP Computer Science Anthony Keen. Computer 101 What happens when you turn a computer on? –BIOS tries to start a system loader –A system loader tries to.
Advertisements

CSM-Java Programming-I Spring,2005 Exceptions Lesson - 7.
CS102--Object Oriented Programming
COMP 121 Week 5: Exceptions and Exception Handling.
Slides prepared by Rose Williams, Binghamton University ICS201 Exception Handling University of Hail College of Computer Science and Engineering Department.
Chapter 11.  Data is often stored in files such as a text file  We need to read that data into our program  Simplest mechanism  Scanner class  First.
1 Lecture 11 Interfaces and Exception Handling from Chapters 9 and 10.
Final Review.
Text File I/O. Text Files and Binary Files Files that are designed to be read by human beings, and that can be read or written with an editor are called.
CS 206 Introduction to Computer Science II 01 / 21 / 2009 Instructor: Michael Eckmann.
EXCEPTIONS Def: An exception is a run-time error. Examples include: attempting to divide by zero, or manipulate invalid data.
1 Chapter 4 Language Fundamentals. 2 Identifiers Program parts such as packages, classes, and class members have names, which are formally known as identifiers.
Files and Streams CS 21a Chapter 11 of Horstmann.
18 File handling1June File handling CE : Fundamental Programming Techniques.
1 Text File I/O Overview l I/O streams l Opening a text file for reading l Reading a text file l Closing a stream l Reading numbers from a text file l.
1 Streams Overview l I/O streams l Opening a text file for reading l Reading a text file l Closing a stream l Reading numbers from a text file l Writing.
Slides prepared by Rose Williams, Binghamton University Chapter 10 File I/O.
CS 206 Introduction to Computer Science II 01 / 23 / 2009 Instructor: Michael Eckmann.
Java. Why Java? It’s the current “hot” language It’s almost entirely object-oriented It has a vast library of predefined objects It’s platform independent.
Object Oriented Programming
Copyright © 2014 by John Wiley & Sons. All rights reserved.1 Chapter 11 – Input/Output and Exception Handling.
1 Review of Java Higher Level Language Concepts –Names and Reserved Words –Expressions and Precedence of Operators –Flow of Control – Selection –Flow of.
CS 46B: Introduction to Data Structures July 7 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak
Exceptions 1. Your computer takes exception Exceptions are errors in the logic of a program (run-time errors). Examples: Exception in thread “main” java.io.FileNotFoundException:
CS 46B: Introduction to Data Structures June 25 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak.
Introduction to Programming David Goldschmidt, Ph.D. Computer Science The College of Saint Rose Java Fundamentals (Comments, Variables, etc.)
The Java Programming Language
Console Input & Output CSS 161: Fundamentals of Computing Joe McCarthy 1.
CS 46B: Introduction to Data Structures June 16 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak.
CS 151: Object-Oriented Design September 24 Class Meeting Department of Computer Science San Jose State University Fall 2013 Instructor: Ron Mak
CS 206 Introduction to Computer Science II 09 / 10 / 2009 Instructor: Michael Eckmann.
File I/O (Input and Output). Why use files? Things stored in files are more permanent than things stored in variables in programs. Things stored in files.
1 Week 12 l Overview of Streams and File I/O l Text File I/O Streams and File I/O.
CS 151: Object-Oriented Design September 26 Class Meeting Department of Computer Science San Jose State University Fall 2013 Instructor: Ron Mak
Java™ How to Program, 10/e © Copyright by Pearson Education, Inc. All Rights Reserved.
Textbook: Data Structures and the Java Collections Framework 3rd Edition by William Collins William Collins.
CS 160: Software Engineering October 22 Class Meeting Department of Computer Science San Jose State University Fall 2014 Instructor: Ron Mak
Strings and Text File I/O (and Exception Handling) Corresponds with Chapters 8 and 17.
CMSC 202 Text File I/O. Aug 8, Text Files and Binary Files Files that are designed to be read by human beings, and that can be read or written with.
Fall 2002CS 150: Intro. to Computing1 Streams and File I/O (That is, Input/Output) OR How you read data from files and write data to files.
Java Programming: From Problem Analysis to Program Design, 4e Chapter 11 Handling Exceptions and Events.
Week 12 – Text Files Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.
COP3502 Programming Fundamentals for CIS Majors 1 Instructor: Parisa Rashidi.
Exceptions in C++. Exceptions  Exceptions provide a way to handle the errors generated by our programs by transferring control to functions called handlers.
Exceptions and Assertions Chapter 15 – CSCI 1302.
 In the java programming language, a keyword is one of 50 reserved words which have a predefined meaning in the language; because of this,
Exception Handling in Java Topics: Introduction Errors and Error handling Exceptions Types of Exceptions Coding Exceptions Summary.
ICS3U_FileIO.ppt File Input/Output (I/O)‏ ICS3U_FileIO.ppt File I/O Declare a file object File myFile = new File("billy.txt"); a file object whose name.
CS 46B: Introduction to Data Structures June 30 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak.
CS 146: Data Structures and Algorithms June 11 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak
© 2006 Pearson Addison-Wesley. All rights reserved 1-1 Chapter 1 Review of Java Fundamentals.
CS 46B: Introduction to Data Structures July 21 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak.
Slides prepared by Rose Williams, Binghamton University Console Input and Output.
COMP 110: Spring Announcements Program 5 Milestone 1 was due today Program 4 has been graded.
Lab 04-2 Objectives:  Understand what a file is.  Learn how to use the File class  Learn how to use the Scanner class to read from files  Learn about.
File Input & Output Sections Outcomes  Know the difference between files and streams  Use a Scanner to read from a file  add “throws” annotations.
Chapter 9: Continuing Classes By Matt Hirsch. Table Of Contents 1.Static Fields and Methods 2.Inheritance I. Recycle Code with Inheritance II. Overriding.
Introduction to Exceptions in Java CS201, SW Development Methods.
FILES AND EXCEPTIONS Topics Introduction to File Input and Output Using Loops to Process Files Processing Records Exceptions.
Classes CS 162 (Summer 2009). Parts of a Class Instance Fields Methods.
Today… StringTokenizer class. Method Overloading. Catching Exceptions (and what they are!). Start Pointers and Aliasing. Winter 2016CMPE212 - Prof. McLeod1.
File I/O (Input and Output)
CMSC 202 Text File I/O.
INPUT/OUTPUT AND EXCEPTION HANDLING
Starting JavaProgramming
CSS 161 Fundamentals of Computing Introduction to Computers & Java
CSS 161: Fundamentals of Computing
Fundamental Error Handling
Unit 3: Variables in Java
Streams A stream is an object that enables the flow of data between a program and some I/O device or file If the data flows into a program, then the stream.
Presentation transcript:

CS 46B: Introduction to Data Structures June 9 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Quiz 6 June 11  Take “Quiz 6 June 11” in Canvas before the start of Thursday’s class. 2

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 3 A Class Hierarchy Puzzle Animal LionDogPiranhaGoldfishParrotHummingbird MammalFishBird  Suppose we want to add the category HouseholdPet. Do we make it a superclass? Where does it belong in this class hierarchy?  What if we also want to add the category Biter ? Java allows a class to inherit from at most one superclass. No “multiple inheritance”

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 4 A Class Hierarchy Puzzle, cont’d  Make HouseholdPet and Biter Java interfaces. A Java class can implement multiple interfaces. Animal MammalFishBird LionDogPiranhaGoldfishParrotHummingbird «interface» HouseholdPet «interface» Biter

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Clicker Question June 9 #1  Suppose we define  Then which of the following is true? a. Method feed(Food f) is automatically private in the classes that don’t implement interface HouseholdPet. b. Method feed(Food f) is automatically public in the classes that do implement interface HouseholdPet. c. We don’t need to implement method feed(Food f) in the classes that also implement interface Biter. d. A class cannot implement both interfaces HouseholdPet and Biter. 5 public interface HouseholdPet { void feed(Food f); }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 6 Java Subclass  If a class C is a subclass of superclass S, then C “is a” S: Dog is a Mammal Dog is an Animal Animal MammalFishBird LionDogPiranhaGoldfishParrotHummingbird

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 7 Java Interface  If a class C implements interface N, then C “is a” N: Dog is a HouseholdPet Dog is a Biter Animal MammalFishBird LionDogPiranhaGoldfishParrotHummingbird «interface» HouseholdPet «interface» Biter

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 8 Java instanceof Operator  If the value of variable x is of type Dog, then the following conditionals are all true: x instanceof Dog x instanceof Mammal x instanceof Animal x instanceof HouseholdPet x instanceof Biter

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 9 Feed Our Pets  How we find and feed all our pets that are in array animals ? public interface HouseholdPet { void feed(Food f); } for (int i = 0; i < animals.length; i++) { if ((animals[i] != null) && (animals[i] instanceof HouseholdPet)) { HouseholdPet pet = (HouseholdPet) animals[i]; Food f = new Food(); pet.feed(f); } }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 10 Feed Our Pets, cont’d  Instead of: you can write: HouseholdPet pet = (HouseholdPet) animals[i]; pet.feed(f); ((HouseholdPet) animals[i]).feed(f); The first way may be easier to write and read!

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 11 Marker Interfaces  What if an interface type doesn’t declare anything? Suppose public interface Biter { // nothing! }  A marker interface is an empty interface that serves to “tag” the classes that implement it. Use the instanceof operator to see which objects are from a tagged class.

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 12 Avoid Biters!  Example of how to use a marker interface: for (int i = 0; i < animals.length; i++) { if ((animals[i] != null) && (animals[i] instanceof Biter)) { // Code that does something // with animals that are biters. // // The code can’t call any // Biter methods because // there aren’t any. } Animal animals[];

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 13 Java Interface Constants  An interface type cannot contain instance variables. Only a class type can have instance variables.  If an interface type definition declares any variables, they are automatically made public static final In other words, they’re constants. Any class that implements the interface shares the constants. public interface HouseholdPet { int VET_VISTS = 2; // visits per year to the vet... }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 14 Objects and Interfaces  If class C implements interface N, then objects of class C can be assigned to variables of the interface type N. public class Dog implements HouseholdPet {... } HouseholdPet pet = new Dog(...); Implements the HouseholdPet interface Interface type

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak 15 Objects and Interfaces, cont’d  The type of an object is never an interface type.  The type of a variable can be an interface type. The value of such a variable is a reference to an object whose class implements the interface type. public class Dog implements HouseholdPet {... } HouseholdPet pet = new Dog(...);

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Break 16

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Reading and Writing Text Files  Most programs need to read input data and write output results.  We will look at how to read input data and write results in the form of text files.  The Scanner class is the most convenient way to read data from a text file.  The PrintWriter class is the most convenient way to write results to a text file. 17

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Create a Scanner Object  The constructor for the Scanner class can have a reference to a File object as its argument:  Or:  The Scanner class lives in the java.util package, so you must import it: 18 File inputFile = new File("myinput.txt"); Scanner in = new Scanner(inputFile); Scanner in = new Scanner(new File("myinput.txt")); import java.util.Scanner;

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Create a PrintWriter Object  The constructor for the PrintWriter class can have either a reference to a File object as its argument, or just the name of the output file:  The PrintWriter class lives in the java.io package, so you must import it: 19 PrintWriter out = new PrintWriter("myoutput.txt"); import java.io.PrintWriter;

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Create a PrintWriter Object, cont’d  What happens if the output file already exists? The file is completely overwritten with new contents.  What happens if the output file doesn’t already exist? A new output file is automatically created. 20

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Close the Input and Output Files  When your program is done with an input or an output file, it should close it:  If you don’t close an output file, the last part of your output may not make it into the file. 21 in.close(); // close the Scanner input file out.close(); // close the PrintWriter output file

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Clicker Question June 9 #2  Consider the statement a. This is a runtime error because the Scanner constructor expects a reference to a file object. b. This is a compile-time error because the Scanner constructor expects a reference to a file object. c. This is acceptable because your program will read from an input file named myinput.txt. d. This is acceptable because your program will read from the string "myinput.txt". 22 Scanner in = new Scanner("myinput.txt");

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Words  The Scanner class’s hasNext() method returns true if there is a word to read next from the input; otherwise, it returns false.  The Scanner class’s next() method reads the next word from the input and returns it as a string. 23

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Words, cont’d  How do you read one word after another from an input text file? Suppose variable in is a reference to a Scanner object: How does this loop work? 24 while (in.hasNext()) { String word = in.next(); System.out.println(word); }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Words, cont’d  If the input file contains  What is the output? 25 while (in.hasNext()) { String word = in.next(); System.out.println(word); } Mary had a little lamb Mary had a little lamb

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Words, cont’d  Java considers a word to be any consecutive sequence of characters that is not “white space”. White space includes any spaces, tabs, and newline characters.  So if the input file contains instead the output will be 26 Mary had 12 little lambs. Mary had 12 little lambs. Why?

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Words, cont’d  You can tell your Scanner object to only read words and discard anything else.  Tell it that any character that is not a letter (upper and lower case) is a “delimiter”. A delimiter is a character that separates one word from another. What are word delimiters by default?  spaces, tabs, and newline characters 27 in.useDelimiter("[^A-Za-z]+"); A “regular expression” that says “one or more characters that is not a letter”.

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Characters  If you want to read a text file one character at a time, set the delimiter to an empty string:  Then in.next() will read the next character, but it will still return it as a string. How to get the character out of the string? 28 in.useDelimiter(""); while (in.hasNext()) { char ch = in.next().charAt(0); /* do something with ch */ }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Classify Characters  Each of the following boolean methods takes a character as an argument. 29 Typo: It should be isWhitespace (lower-case s).

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Lines  The Scanner class’s hasNextLine() method returns true if there is a line to read next from the input; otherwise, it returns false.  The Scanner class’s nextLine() method reads the next line from the input and returns it as a string. 30

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Lines, cont’d  How do you read one line after another from an input text file? Suppose variable in is a reference to a Scanner object: How does this loop work? 31 while (in.hasNextLine()) { String line = in.nextLine(); System.out.println(line); }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Numbers  The Scanner class has methods to read numbers, including: hasNextInt() and nextInt() hasNextLong() and nextLong() hasNextDouble() and nextDouble() 32

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Read Numbers, cont’d  Note that if a number is the last item in an input line, methods nextInt(), nextLong(), and nextDouble() will not read the following newline character.  Therefore, a subsequent call to nextLine() will read an empty string.  So you will need yet another call to nextLine() to read the next input line. 33

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Handle I/O Errors  Examples of runtime I/O errors: Attempt to read a file that doesn’t exist. Attempt to read a number from an input text file but there isn’t a number.  At run time, Java will detect I/O errors.  It is your program’s responsibility to handle the errors. What should your program do when an I/O error occurs? 34

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Introduction to Exception Handling  Java exception handling is a flexible means of transferring runtime control: From the point an exception (error) is detected To special code to handle (deal with) the error. 35 try { /* code that can cause an exception, such as an attempt to read a nonexistent file. */ } catch (FileNotFoundException ex) { /* code to handle the exception, such as writing an error message. */ }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Introduction to Exception Handling, cont’d  When a statement inside a try block causes an exception, your program immediately branches to the catch block.  After executing the catch block, your program continues to the next statement. It does not resume executing the try block. 36 try {... } catch (SomeException ex) {... } The exception variable ex contains useful information about the exception that just occurred.

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak FileNotFoundException Handler Example 37 public int countLines() { int count = 0; Scanner in = null; try { in = new Scanner(inputFile); while (in.hasNextLine()) { in.nextLine(); ++count; } } catch (FileNotFoundException ex) { ex.printStackTrace(); } return count; }

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak The finally Clause  Add a finally block to a try-catch statement for code that should be executed after the try block, whether or not an exception occurred. 38 try { in = new Scanner(inputFile);... } catch (FileNotFoundException ex) { ex.printStackTrace(); } finally { if (in != null) in.close(); } No matter whether the try block executed normally, or an exception occurred and the catch block executed, we will always close the input file. Why do we need to check whether in is null?

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Homework #2  Write a Java program that will read Lincoln’s Gettysburg Address from a text file.  Count and print how many lines, words, and characters are in the text file. Just use the default word delimiters.  Calculate and print what percentage of the file’s characters are digits lower-case letters upper-case letters 39 white-space characters other characters

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Homework #2, cont’d  Draft: Due Wednesday, June 10 at 11:59 PM Just count and print the number of lines, words, and characters. URL: 4tuyws7nwgo420hi8tkw8 4tuyws7nwgo420hi8tkw8  Final: Due Friday, June 12 at 11:59 PM Also calculate and print the percentages. URL: b7ctd13x92r8zy4xs7h7y b7ctd13x92r8zy4xs7h7y 40 Canvas: Homework 2 Draft Canvas: Homework 2 Final

Computer Science Dept. Summer 2015: June 9 CS 46B: Introduction to Data Structures © R. Mak Homework #2, cont’d  Input file GettysburgAddress.txt : ts/2/GettysburgAddress.txt ts/2/GettysburgAddress.txt  Your solution must Use the Scanner class for the input file. Always close an open input file. Catch and handle runtime I/O errors.  For this assignment, to count lines, words, and characters, it’s probably easiest to open, read, and close the input file three times. 41