Chapter 17 Files Streams and Object Serialization Java
Chapter 17 Files, Streams and Object Serialization Java How to Program, 8/e © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 2 The java. io Package Java programs perform file processing by using classes from package java. io. Includes definitions for stream classes § § File. Input. Stream (for byte-based input from a file) File. Output. Stream (for byte-based output to a file) File. Reader (for character-based input from a file) File. Writer (for character-based output to a file) You open a file by creating an object of one these stream classes. The object’s constructor opens the file. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 2 The java. io Package(cont. ) Can perform input and output of objects or variables of primitive data types without having to worry about the details of converting such values to byte format. To perform such input and output, objects of classes Object. Input. Stream and Object. Output. Stream can be used together with the byte-based file stream classes File. Input. Stream and File. Output. Stream. The complete hierarchy of classes in package java. io can be viewed in the online documentation at http: //java. sun. com/javase/6/docs/api/ja va/io/package-tree. html © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 2 The java. io Package (cont. ) Class File provides information about files and directories. Character-based input and output can be performed with classes Scanner and Formatter. § Class Scanner is used extensively to input data from the keyboard. This class can also read data from a file. § Class Formatter enables formatted data to be output to any text-based stream in a manner similar to method System. out. printf. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 3 Class File provides four constructors. The one with a String argument specifies the name of a file or directory to associate with the File object. § The name can contain path information as well as a file or directory name. § A file or directory’s path specifies its location on disk. § An absolute path contains all the directories, starting with the root directory, that lead to a specific file or directory. § A relative path normally starts from the directory in which the application began executing and is therefore “relative” to the current directory. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 3 Class File (cont. ) The constructor with two String arguments specifies an absolute or relative path and the file or directory to associate with the File object. The constructor with File and String arguments uses an existing File object that specifies the parent directory of the file or directory specified by the String argument. The fourth constructor uses a URI object to locate the file. § A Uniform Resource Identifier (URI) is a more general form of the Uniform Resource Locators (URLs) that are used to locate websites. Figure 17. 1 lists some common File methods. The http: //java. sun. com/javase/6/docs/api/ja va/io/File. html © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 3 Class File (cont. ) A separator character is used to separate directories and files in the path. On Windows, the separator character is a backslash (). On Linux/UNIX, it’s a forward slash (/). Java processes both characters identically in a path name. When building Strings that represent path information, use File. separator to obtain the local computer’s proper separator. § This constant returns a String consisting of one character— the proper separator for the system. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 4 Case study: A Credit-Inquiry Program To retrieve data sequentially from a file, programs start from the beginning of the file and read all the data consecutively until the desired information is found. It might be necessary to process the file sequentially several times (from the beginning of the file) during the execution of a program. Class Scanner does not allow repositioning to the beginning of the file. § The program must close the file and reopen it. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 4 Case study: A Credit-Inquiry Program The data in many sequential files cannot be modified without the risk of destroying other data in the file. If the name “White” needed to be changed to “Worthington, ” the old name cannot simply be overwritten, because the new name requires more space. Fields in a text file—and hence records—can vary in size. Records in a sequential-access file are not usually updated in place. Instead, the entire file is usually rewritten. Rewriting the entire file is uneconomical to update just one record, but reasonable if a substantial number of records need to be updated. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5 Object Serialization To read an entire object from or write an entire object to a file, Java provides object serialization. A serialized object is represented as a sequence of bytes that includes the object’s data and its type information. After a serialized object has been written into a file, it can be read from the file and deserialized to recreate the object in memory. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5 Object Serialization (cont. ) Classes Object. Input. Stream and Object. Output. Stream, which respectively implement the Object. Input and Object. Output interfaces, enable entire objects to be read from or written to a stream. To use serialization with files, initialize Object. Input. Stream and Object. Output. Stream objects with File. Input. Stream and File. Output. Stream objects. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5 Object Serialization (cont. ) Object. Output interface method write. Object takes an Object as an argument and writes its information to an Output. Stream. A class that implements Object. Ouput (such as Object. Output. Stream) declares this method and ensures that the object being output implements Serializable. Object. Input interface method read. Object reads and returns a reference to an Object from an Input. Stream. § After an object has been read, its reference can be cast to the object’s actual type. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5. 1 Creating a Sequential-Access File Using Object Serialization Objects of classes that implement interface Serializable can be serialized and deserialized with Object. Output. Streams and Object. Input. Streams. Interface Serializable is a tagging interface. § It does not contain methods. A class that implements Serializable is tagged as being a Serializable object. An Object. Output. Stream will not output an object unless it is a Serializable object. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5. 1 Creating a Sequential-Access File Using Object Serialization (cont. ) In a class that implements Serializable, every variable must be Serializable. Any one that is not must be declared transient so it will be ignored during the serialization process. All primitive-type variables are serializable. For reference-type variables, check the class’s documentation (and possibly its superclasses) to ensure that the type is Serializable. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5. 2 Reading and Deserializing Data from a Sequential-Access File The program in Figs. 17. 10– 17. 21 reads records from a file created by the program in Section 17. 5. 1 and displays the contents. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 5. 2 Reading and Deserializing Data from a Sequential-Access File (cont. ) Object. Input. Stream method read. Object reads an Object from a file. Method read. Object throws an EOFException if an attempt is made to read beyond the end of the file. Method read. Object throws a Class. Not. Found. Exception if the class for the object being read cannot be located. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6 Additional java. io Classes This section overviews additional interfaces and classes (from package java. io) for byte-based input and output streams and character-based input and output streams. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output Input. Stream and Output. Stream are abstract classes that declare methods for performing byte-based input and output, respectively. Pipes are synchronized communication channels between threads. § Piped. Output. Stream (a subclass of Output. Stream) and Piped. Input. Stream (a subclass of Input. Stream) establish pipes between two threads in a program. § One thread sends data to another by writing to a Piped. Output. Stream. § The target threads information from the pipe via a Piped. Input. Stream. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) A Filter. Input. Stream filters an Input. Stream, and a Filter. Output. Stream filters an Output. Stream. Filtering means simply that the filter stream provides additional functionality, such as aggregating data bytes into meaningful primitive-type units. Filter. Input. Stream and Filter. Output. Stream are typically extended, so some of their filtering capabilities are provided by their subclasses. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) A Print. Stream (a subclass of Filter. Output. Stream) performs text output to the specified stream. System. out and System. err are Print. Stream objects. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) Usually, programs read data as aggregates of bytes that form ints, floats, doubles and so on. Java programs can use several classes to input and output data in aggregate form. Interface Data. Input describes methods for reading primitive types from an input stream. Classes Data. Input. Stream and Random. Access. File each implement this interface to read sets of bytes and process them as primitive-type values. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) Interface Data. Output describes a set of methods for writing primitive types to an output stream. Classes Data. Output. Stream (a subclass of Filter. Output. Stream) and Random. Access. File each implement this interface to write primitive-type values as bytes. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) Buffering is an I/O-performance-enhancement technique. With a Buffered. Output. Stream, each output operation is directed to a buffer § holds the data of many output operations Transfer to the output device is performed in one large physical output operation each time the buffer fills. The output operations directed to the output buffer in memory are often called logical output operations. A partially filled buffer can be forced out to the device at any time by invoking the stream object’s flush method. Using buffering can greatly increase the performance of an application. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) With a Buffered. Input. Stream, many “logical” chunks of data from a file are read as one large physical input operation into a memory buffer. As a program requests each new chunk of data, it’s taken from the buffer. This procedure is sometimes referred to as a logical input operation. When the buffer is empty, the next actual physical input operation from the input device is performed. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) Java stream I/O includes capabilities for inputting from byte arrays in memory and outputting to byte arrays in memory. A Byte. Array. Input. Stream (a subclass of Input. Stream) reads from a byte array in memory. A Byte. Array. Output. Stream (a subclass of Output. Stream) outputs to a byte array in memory. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 1 Interfaces and Classes for Byte. Based Input and Output (cont. ) A Sequence. Input. Stream (a subclass of Input. Stream) logically concatenates several Input. Streams The program sees the group as one continuous Input. Stream. When the program reaches the end of one input stream, that stream closes, and the next stream in the sequence opens. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 2 Interfaces and Classes for Character-Based Input and Output The Reader and Writer abstract classes are Unicode two-byte, character-based streams. Most of the byte-based streams have corresponding character-based concrete Reader or Writer classes. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 2 Interfaces and Classes for Character-Based Input and Output (cont. ) Classes Buffered. Reader (a subclass of abstract class Reader) and Buffered. Writer (a subclass of abstract class Writer) enable buffering for character-based streams. Classes Char. Array. Reader and Char. Array. Writer read and write, respectively, a stream of characters to a char array. A Line. Number. Reader (a subclass of Buffered. Reader) is a buffered character stream that keeps track of the number of lines read. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 6. 2 Interfaces and Classes for Character-Based Input and Output (cont. ) An Input. Stream can be converted to a Reader via class Input. Stream. Reader. An Ouput. Stream can be converted to a Writer via class Output. Stream. Writer. Class File-Reader and class File. Writer read characters from and write characters to a file. Class Piped. Reader and class Piped. Writer implement piped-character streams for transfering data between threads. Class String. Reader b. String. Writer read characters from and write characters to Strings. A Print. Writer writes characters to a stream. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 7 Opening Files with JFile. Chooser Class JFile. Chooser displays a dialog that enables the user to easily select files or directories. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
© 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
17. 7 Opening Files with JFile. Chooser (cont. ) JFile-Chooser method set. File-Selection. Mode specifies what the user can select from the file. Chooser. JFile. Chooser static constant FILES_AND_DIRECTORIES indicates that files and directories can be selected. Other static constants include FILES_ONLY (the default) and DIRECTORIES_ONLY. Method show. Open. Dialog displays a JFile. Chooser dialog titled Open. A JFile. Chooser dialog is a modal dialog. Method show. Open. Dialog returns an integer specifying which button (Open or Cancel) the user clicked to close the dialog. JFile. Chooser method get. Selected. File returns the selected file as a File object. © 1992 -2010 by Pearson Education, Inc. All Rights Reserved.
- Slides: 81