Download presentation
Presentation is loading. Please wait.
Published byStephany Fowler Modified over 9 years ago
1
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
2
Fall 2002CS 150: Intro. to Computing2 Streams Abstractly, a stream is a flow of data –Data could be characters, numbers, bytes consisting of binary digits, bytes consisting of binary encoding of objects, etc. If the data flows “out” of your program (and, say, to a file or the monitor) then the stream is an output stream If the data flows “in” to your program, then the stream is an input stream
3
Fall 2002CS 150: Intro. to Computing3 Streams In Java, file I/O (and also simple keyboard/monitor I/O) is handled by streams –In Java, a stream is an object that either delivers data to its destination (such as a file or monitor) or takes data from a source (such as a file or keyboard) and delivers it to your program –System.out is an example of an output stream
4
Fall 2002CS 150: Intro. to Computing4 Streams Program File, Monitor, Network, Etc. File, Keyboard, Network, Etc. output stream input stream
5
Fall 2002CS 150: Intro. to Computing5 Remember: An input stream moves data into your program (not into a file) An output stream moves data out of your program (not out of the file)
6
Fall 2002CS 150: Intro. to Computing6 Binary vs Text Files All data in any file is stored as a sequence of bits. But, sometimes we “think” of the file as consisting of a sequence of characters (for example, your Java source code files), and some we think of as simply containing a sequence of binary digits (such as a file containing the machine code for a program) The files of characters are called text files The files of bits are called binary files Java has objects to handle I/O to both kinds of files. We’ll only work with text files
7
Fall 2002CS 150: Intro. to Computing7 Text File I/O Best to just start with an example: we’ll add some file I/O to StudentRecord Must be here!
8
Fall 2002CS 150: Intro. to Computing8 Text File I/O (cont.) We use the println() method in the class PrintWriter (not System.out.println(), but acts the same) Returns a reference to an OutputStream object
9
Fall 2002CS 150: Intro. to Computing9
10
Fall 2002CS 150: Intro. to Computing10
11
Fall 2002CS 150: Intro. to Computing11 What’s with these?!
12
Fall 2002CS 150: Intro. to Computing12 Another Look…
13
Fall 2002CS 150: Intro. to Computing13 What’s With This try … catch Thing?! This is an example of exception handling in Java (which we may cover more completely at a later date) For now, know that this says: execute the statements in the try block. If something goes wrong, then stop and execute the statements in the catch block –Lots can go wrong with file I/O (e.g. the file may not exist, or you may not have permission to access it)
14
Fall 2002CS 150: Intro. to Computing14 Subtle and Very Important… If written this way, the variable outputStream is local to the try block!
15
Fall 2002CS 150: Intro. to Computing15 Still Another Look… Here it’s visible throughout the whole method What’s with this?!
16
Fall 2002CS 150: Intro. to Computing16 So, How Do We Use These Things?! Just like you use System.out.println(), though there are also methods specially designed to print doubles, chars, etc.
17
Fall 2002CS 150: Intro. to Computing17 Writing To a File (cont.) This is a variable name! I could have called it any legal variable name.
18
Fall 2002CS 150: Intro. to Computing18 Writing To a File (cont.) Why don’t I need to use getName() here?
19
Fall 2002CS 150: Intro. to Computing19 Still More Writing To a File
20
Fall 2002CS 150: Intro. to Computing20
21
Fall 2002CS 150: Intro. to Computing21 close() the Stream! Calling the close() method: –Flushes the stream –Operating system releases all resources needed to connect the stream to the file, and performs other housekeeping –If stream isn’t closed, Java closes it when the program ends, but you’re taking a chance… If program ends abnormally, then Java may not be able to automatically close the stream and you could lose data You need to close a stream before reading from the same file
22
Fall 2002CS 150: Intro. to Computing22 A True Story…
23
Fall 2002CS 150: Intro. to Computing23 Why Ever flush() a Stream? There are situations where you want the stream to remain open (you’re still using it), but you need to be sure data goes to output device Writing to a network interface During long operations on a file, flush stream in case there is some kind of abnormality –OS crash, etc.
24
Fall 2002CS 150: Intro. to Computing24 Miscellaneous File names: The file name you give Java is simply a String. It doesn’t know about suffixes and the like. That’s the OS’s thing. Opening a text file for appending: Indicates open for appending
25
Fall 2002CS 150: Intro. to Computing25 Streams and File I/O Part II Reading from Files
26
Fall 2002CS 150: Intro. to Computing26 BufferedReader Class The BufferedReader class is the input stream equivalent of the PrintWriter class –The constructor requires a similar setup –The class methods are analogous –Remember to import java.io.* –Remember this is for reading text files
27
Fall 2002CS 150: Intro. to Computing27
28
Fall 2002CS 150: Intro. to Computing28 The FileReader class is a subclass of the Reader class, so using it in the constructor is “legal”
29
Fall 2002CS 150: Intro. to Computing29
30
Fall 2002CS 150: Intro. to Computing30 What’s with this override thing? Note the exceptions that can be thrown
31
Fall 2002CS 150: Intro. to Computing31 Reading From Files As with writing to files, you need to know “where” you are in the file when reading Unlike with writing, you need to know when you have run out of stuff to read in the file When reading, you generally need to have a place (i.e. a variable) to put the data you have read Beware: there are many subtleties here
32
Fall 2002CS 150: Intro. to Computing32 Anything look strange here? It should!
33
Fall 2002CS 150: Intro. to Computing33
34
Fall 2002CS 150: Intro. to Computing34 Example Some new file-reading code added to the code that created the file profsGrades.txt
35
Fall 2002CS 150: Intro. to Computing35 Example (cont.) Adding a simple cast to a char will fix this problem, but there are others (see next slide)
36
Fall 2002CS 150: Intro. to Computing36
37
Fall 2002CS 150: Intro. to Computing37 Note the Changes… The entirety of the input code is in the try block (including closing the stream), not just the memory allocation for the stream There are two different classes of exceptions that are caught here: FileNotFoundException and IOException This is how you should write your I/O code!
38
Fall 2002CS 150: Intro. to Computing38 Running the Example Code
39
Fall 2002CS 150: Intro. to Computing39 Augmenting Our Code What the read documentation didn’t tell you is that the read() method returns the integer value 1 if there is no more file to read We’ll use this to modify our code to read (and print to standard output) the entire file
40
Fall 2002CS 150: Intro. to Computing40 NOTE! (see next slide)
41
Fall 2002CS 150: Intro. to Computing41 Notes From Last Slide myChar is declared an int, since we’ll need to check an integer value to see if we’re at the end of the file We use an infinite loop to keep iterating until we’ve read the entire file We call the read() method within the conditional for the if statement. Regardless of whether the condition is true, the call to read() occurs (this is a standard hack for this kind of code)
42
Fall 2002CS 150: Intro. to Computing42 More Notes… We use the print() method as opposed to the println() method – when a newline character is encountered, this will cause a new line in the output We perform the cast to char inside the System.out.print () statement
43
Fall 2002CS 150: Intro. to Computing43 There Are Easier Ways Use another version of the read() method to read characters into a char array Use the readline() method, which reads a whole line at a time into a String
44
Fall 2002CS 150: Intro. to Computing44
45
Fall 2002CS 150: Intro. to Computing45 More read() Documentation
46
Fall 2002CS 150: Intro. to Computing46 Often the Best Way…
47
Fall 2002CS 150: Intro. to Computing47 A problem
48
Fall 2002CS 150: Intro. to Computing48 The Problem The readLine() method returns the value null if it reaches the end of file. When this happens, the variable currentLine is assigned the value null, which causes a NullPointerException when we try to call its equals() method in the if statement. See the fix on either of the next two slides (the first is the recommended fix)
49
Fall 2002CS 150: Intro. to Computing49 A fix
50
Fall 2002CS 150: Intro. to Computing50 Another fix
51
Fall 2002CS 150: Intro. to Computing51 Reading Numeric Data Types Note that using any of the BufferedReader methods results in reading either a String or a char. To read a double or int or other numerical data type, you need to –Use methods like stringToInt() –Use methods like Double.parseDouble(String input) The method Integer.parseInt(String input) is the exact equivalent of stringToInt()
52
Fall 2002CS 150: Intro. to Computing52 Finally, Reading Input From the Keyboard The keyboard is an input device like any other, and we can read it with an input stream We use the read() m ethod in System.in –This works like our other read() method, but reads from the keyboard We use the above read() method to create a static readLine() method that we can call to read from the keyboard
53
Fall 2002CS 150: Intro. to Computing53
54
Fall 2002CS 150: Intro. to Computing54 This is needed in order to handle both Unix and Windows style end of line conventions
55
Fall 2002CS 150: Intro. to Computing55 A Tester For KeyboardIn Don’t forget that we need to use a try block with this
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.