1.22k likes | 1.23k Views
Learn how to create, read, write, and update files in Java, as well as use different classes and techniques for file processing and manipulation. Explore the concept of streams and different file types.
E N D
14 • Files and Streams
I can only assume that a “Do Not File” document is filed in a “Do Not File” file. Senator Frank Church Senate Intelligence Subcommittee Hearing, 1975 Consciousness does not appear to itself chopped up in bits. A “river” or a “stream” are the metaphors by which it is most naturally described. William James I read part of it all the way through. Samuel Goldwyn A great memory does not make a philosopher, any more than a dictionary can be called grammar. John Henry, Cardinal Newman
OBJECTIVES In this chapter you will learn: • To create, read, write and update files. • To use class File to retrieve information about files and directories. • The Java input/output stream class hierarchy. • The differences between text files and binary files. • Sequential-access and random-access file processing. • To use classes Scanner and Formatter to process text files. • To use the FileInputStream and FileOutputStream classes. • To use a JFileChooser dialog. • To use the ObjectInputStream and ObjectOutputStream classes. • To use class RandomAccessFile.
14.1 Introduction • 14.2 Data Hierarchy • 14.3 Files and Streams • 14.4 Class File • 14.5 Sequential-Access Text Files • 14.5.1 Creating a Sequential-Access Text File • 14.5.2 Reading Data from a Sequential-Access Text File • 14.5.3 Case Study: A Credit-Inquiry Program • 14.5.4 Updating Sequential-Access Files
14.6 Object Serialization • 14.6.1 Creating a Sequential-Access File Using Object Serialization • 14.6.2 Reading and Deserializing Data from a Sequential- Access File • 14.7 Random-Access Files • 14.7.1 Creating a Random-Access File • 14.7.2 Writing Data Randomly to a Random-Access File • 14.7.3 Reading Data Sequentially from a Random-Access File • 14.7.4 Case Study: A Transaction-Processing Program • 14.8 Additional java.io Classes • 14.9 Opening Files with JFileChooser • 14.10 Wrap-Up
14.1 Introduction • Storage of data in variables and arrays is temporary • Files used for long-term retention of large amounts of data, even after the programs that created the data terminate • Persistent data – exists beyond the duration of program execution • Files stored on secondary storage devices • Stream – ordered data that is read from or written to a file
14.2 Data Hierarchy • Computers process all data items as combinations of zeros and ones • Bit – smallest data item on a computer, can have values 0 or 1 • Byte – 8 bits • Characters – larger data item • Consists of decimal digits, letters and special symbols • Character set – set of all characters used to write programs and represent data items • Unicode – characters composed of two bytes • ASCII
14.2 Data Hierarchy • Fields – a group of characters or bytes that conveys meaning • Record – a group of related fields • File – a group of related records • Data items processed by computers form a data hierarchy that becomes larger and more complex from bits to files • Record key – identifies a record as belonging to a particular person or entity – used for easy retrieval of specific records • Sequential file – file in which records are stored in order by the record-key field • Database – a group of related files • Database Management System – a collection of programs designed to create and manage databases
14.3 Files and Streams • Java views each files as a sequential stream of bytes • Operating system provides mechanism to determine end of file • End-of-file marker • Count of total bytes in file • Java program processing a stream of bytes receives an indication from the operating system when program reaches end of stream
14.3 Files and Streams • File streams • Byte-based streams – stores data in binary format • Binary files – created from byte-based streams, read by a program that converts data to human-readable format • Character-based streams – stores data as a sequence of characters • Text files – created from character-based streams, can be read by text editors • Java opens file by creating an object and associating a stream with it • Standard streams – each stream can be redirected • System.in – standard input stream object, can be redirected with method setIn • System.out – standard output stream object, can be redirected with method setOut • System.err – standard error stream object, can be redirected with method setErr
14.3 Files and Streams • java.io classes • FileInputStream and FileOutputStream – byte-based I/O • FileReader and FileWriter – character-based I/O • ObjectInputStream and ObjectOutputStream – used for input and output of objects or variables of primitive data types • File – useful for obtaining information about files and directories • Classes Scanner and Formatter • Scanner – can be used to easily read data from a file • Formatter – can be used to easily write data to a file
14.4 Class File • Class File useful for retrieving information about files and directories from disk • Objects of class File do not open files or provide any file-processing capabilities
Creating File Objects • Class File provides four constructors: • Takes String specifying name and path (location of file on disk) • Takes two Strings, first specifying path and second specifying name of file • Takes File object specifying path and String specifying name of file • Takes URI object specifying name and location of file • Different kinds of paths • Absolute path – contains all directories, starting with the root directory, that lead to a specific file or directory • Relative path – normally starts from the directory in which the application began executing
Error-Prevention Tip 14.1 • Use File method isFile to determine whether a File object represents a file (not a directory) before attempting to open the file.
Demonstrating Class File • Common File methods • exists – return true if file exists where it is specified • isFile – returns true if File is a file, not a directory • isDirectory – returns true if File is a directory • getPath – return file path as a string • list – retrieve contents of a directory • Separator character – used to separate directories and files in a path • Windows uses \ • UNIX uses / • Java process both characters, File.pathSeparator can be used to obtain the local computer’s proper separator character
Create new File object; user specifies file name and path Returns true if file or directory specified exists Retrieve name of file or directory Retrieve path entered as a string Returns true if name is a file, not a directory Returns true if name is a directory, not a file Returns true if path was an absolute path Retrieve time file or directory was last modified (system-dependent value) Retrieve length of file in bytes Retrieve parent directory (path where File object’s file or directory can be found) Retrieve absolute path of file or directory Outline • FileDemonstration • .java • (1 of 2)
Returns true if File is a directory, not a file Retrieve and display contents of directory Outline • FileDemonstration • .java • (2 of 2)
Outline • FileDemonstration • Test.java • (1 of 3)
Outline • FileDemonstration • Test.java • (2 of 3)
Outline • FileDemonstration • Test.java • (3 of 3)
Common Programming Error 14.1 • Using \ as a directory separator rather than \\ in a string literal is a logic error. A single \ indicates that the \ followed by the next character represents an escape sequence. Use \\ to insert a \ in a string literal.
14.5 Sequential-Access Text Files • Records are stored in order by record-key field • Can be created as text files or binary files
14.5.1 Creating a Sequential-Access Text File • Java imposes no structure on a file, records do not exist as part of the Java language • Programmer must structure files • Formatter class can be used to open a text file for writing • Pass name of file to constructor • If file does not exist, will be created • If file already exists, contents are truncated (discarded) • Use method format to write formatted text to file • Use method close to close the Formatter object (if method not called, OS normally closes file when program exits)
14.5.1 Creating a Sequential-Access Text File • Possible exceptions • SecurityException – occurs when opening file using Formatter object, if user does not have permission to write data to file • FileNotFoundException – occurs when opening file using Formatter object, if file cannot be found and new file cannot be created • NoSuchElementException – occurs when invalid input is read in by a Scanner object • FormatterClosedException – occurs when an attempt is made to write to a file using an already closed Formatter object
Outline • AccountRecord.java • (1 of 3)
Outline • AccountRecord.java • (2 of 3)
Outline • AccountRecord.java • (3 of 3)
Used for writing data to file Open file clients.txt for writing Used for retrieving input from user Object used to output data to file Outline • CreateTextFile • .java • (1 of 4)
Create Scanner to retrieve input from user Create AccountRecord to be filled with user input Outline • CreateTextFile • .java • (2 of 4)
Retrieve input, store data in AccountRecord Write AccountRecord information to file File closed while trying to write to it Loop while user is entering input Outline • CreateTextFile • .java • (3 of 4)
Error with input entered by user Close file Outline • CreateTextFile • .java • (4 of 4)
Fig.14.8 | End-of-file key combinations for various popular operating systems.
Outline • CreateTextFileTest • .java • (1 of 2)
Outline • CreateTextFileTest • .java • (2 of 2)
14.5.2 Reading Data from a Sequential-Access Text File • Data is stored in files so that it may be retrieved for processing when needed • Scanner object can be used to read data sequentially from a text file • Pass File object representing file to be read to Scanner constructor • FileNotFoundException occurs if file cannot be found • Data read from file using same methods as for keyboard input – nextInt, nextDouble, next, etc. • IllegalStateException occurs if attempt is made to read from closed Scanner object
Open file clients.txt for reading Outline • ReadTextFile.java • (1 of 3)
While there is data to be read from file Read data from file, store in AccountRecord Create AccountRecord to store input from file Display AccountRecord contents Outline • ReadTextFile.java • (2 of 3)
Close file Outline • ReadTextFile.java • (3 of 3)
Outline • ReadTextFileTest • .java
14.5.3 Case Study: A Credit-Inquiry Program • To retrieve data sequentially from a file, programs normally start reading from beginning of the file and read all the data consecutively until desired information is found • Class Scanner provides no way to reposition to beginning of file • Instead, file is closed and reopened
Outline • MenuOption.java
AccountRecord stores record being read from file Scanner used to read data from file Outline • CreditInquiry.java • (1 of 6)
Open file clients.txt for reading Retrieve input, store data in AccountRecord Check if record is of requested type Close Scanner While there is data to read from file Display record data to screen Outline • CreditInquiry.java • (2 of 6)
Method determines if record is of proper type Close file Outline • CreditInquiry.java • (3 of 6)
Loop until user enters valid request Retrieve request entered Outline • CreditInquiry.java • (4 of 6)