Chapter Two Streams and File I/O
Chapter Two Streams and File I/O
1
Introduction
• Java uses the concept of a stream to make I/O operation fast.
• I/O means Input/Output.
• The java.io package contains all the classes required for input and
output operations.
• A stream can be defined as a sequence of data.
• An I/O Stream is a sequence of data that is read from a source and
write to a destination.
• All these streams represent an input source and an output destination.
input output
Source Program Destination
stream stream
keyboard or file screen or file
2
The Java File Class
• Java File class represents the files and directory pathnames in an
abstract manner.
• The File class is useful for retrieving information about files or
directories from disk.
• The File class contains the methods for obtaining the properties of
a file/directory and for renaming and deleting a file/directory.
• The File class has different methods which can be used to
manipulate the files.
– Absolute path: An absolute file name (or full name) contains a
file name with its complete path and drive letter.
– Relative path: A relative file name is in relation to the current
working directory.
3
The File Class
4
Example: The File Class
This program demonstrates how to create a File object and use the methods in the File
class to obtain its properties. The program creates a File object for the file us.gif.
The lastModified() method returns the date and time when the file was last modified. 5
Text File and Binary File
7
File Input and Output
Scanner input = new Scanner(new File("temp.txt"));
System.out.println(input.nextLine());
9
PrintWrite Class
10
Example: wring data using PrintWriter
11
Example: reading data using Scanner
12
File Dialogs
• The JFileChooser class is a GUI component which is used for
displaying a file dialog.
• The JFileChooser class is found in the java package
javax.swing.JFileChooser.
13
Example: File Dialogs
14
Types I/O Streams/Files
15
1. Byte I/O Streams
• It is an input and output data in its binary format.
• Java byte streams are used to perform input and
output of 8-bit bytes.
• All byte stream classes are descended from two
abstract classes: InputStream and OutputStream.
• The InputStream is used to read data from a
source and the OutputStream is used for writing
data to a destination.
• There are many classes related to byte streams but
the most frequently used classes are,
FileInputStream and FileOutputStream. 16
1. Byte I/O Streams
• Computers do not differentiate between binary files and text files.
• All files are stored in binary format, and thus all files are essentially binary files. Text I/O requires
• For example, suppose you write the string "199" using text I/O to a file.
• The ASCII or Unicode code for character 1 is 49 (0x31 in hex) and for character 9 is 57 (0x39 in
hex).
• Thus, to write the characters 199, three bytes— 0x31, 0x39, and 0x39—are sent to the output, as
• When you write a byte to a file, the original byte is copied into the file.
• When you read a byte from a file, the exact byte in the file is returned.
• For example, a byte-type value 199 is represented as 0xC7 in the memory and appears exactly as
Binary I/O is more efficient than text I/O, because binary I/O does not require
encoding and decoding. Binary files are independent of the encoding scheme on
the host machine and thus are portable. Java programs on any machine can read a
binary file created by a Java program. This is why Java class files are binary files.
Java class files can run on a JVM on any machine.
18
1. Byte I/O Classes
The abstract InputStream is the root class for reading byte data
and the abstract OutputStream is the root class for writing byte
data.
19
InputStream
The value returned is a byte as an int type.
20
OutputStream
21
FileInputStream/FileOutputStream
23
FileOutputStream
To construct a FileOutputStream, use the following constructors:
public FileOutputStream(String filename)
If the file already exists, the first two constructors would delete the
current contents in the file.
To retain the current content and append new data into the file, use the
last two constructors by passing true to the append parameter. 24
Example: FileInputStream/FileOutputStream
import java.io.*;
public class TestFileStream {
public static void main(String[] args) thorw IOException {
// Create an output stream to the file
FileOutputStream output = new FileOutputStream("temp.dat");
Filter streams are streams that filter bytes for some purpose. The basic byte input stream
provides a read method that can only be used for reading bytes. If you want to read
integers, doubles, or strings, you need a filter class to wrap the byte input stream. Using a
filter class enables you to read integers, doubles, and strings instead of bytes and
characters. FilterInputStream and FilterOutputStream are the base classes for filtering data.
When you need to process primitive numeric types, use DataInputStream and
DataOutputStream to filter bytes.
26
DataInputStream/DataOutputStream
28
DataOutputStream
DataOutputStream extends FilterOutputStream and implements the DataOutput interface.
29
Characters and Strings in Byte I/O
• A Unicode consists of two bytes. The writeChar(char c) method
writes the Unicode of character c to the output.
• The writeChars(String s) method writes the Unicode for each
character in the string s to the output.
• The writeBytes(String s) method writes the lower byte of the
Unicode for each character in the string s to the output.
• The high byte of the Unicode is discarded.
• The writeBytes method is suitable for strings that consist of ASCII
characters, since an ASCII code is stored only in the lower byte of
a Unicode.
• If a string consists of non-ASCII characters, you have to use the
writeChars method to write the string.
30
Characters and Strings in Byte I/O
Why UTF-8? What is UTF-8?
• The statements given below create data streams. The first statement
creates an input stream for file in.dat; the second statement creates an
output stream for file out.dat.
DataInputStream infile = new DataInputStream(new FileInputStream("in.dat"));
34
BufferedInputStream/BufferedOutputStream
Using buffers to speed up I/O
37
Constructing
BufferedInputStream/BufferedOutputStream
// Create a BufferedInputStream
// Create a BufferedOutputStream
38
BufferedInputStream/BufferedOutputStream
BufferedInputStream(new FileInputStream("temp.dat")));
39
ObjectInputStream/ObjectOutputStream
DataInputStream/DataOutputStream enables you to perform I/O for primitive
type values and strings. ObjectInputStream/ObjectOutputStream enables you to
perform I/O for objects in addition for primitive type values and strings.
40
ObjectInputStream/ObjectOutputStream
• ObjectInputStream/ObjectOutputStream classes can be used to
read/write serializable objects.
• DataInputStream/DataOutputStream enables you to perform I/O for
primitive type values and strings.
• ObjectInputStream/ObjectOutputStream enables you to perform
I/O for objects in addition to primitive type values and strings.
• Since ObjectInputStream/ObjectOutputStream contains all the
functions of DataInputStream/DataOutputStream, you can replace
DataInputStream/DataOutputStream completely with
ObjectInputStream/ObjectOutputStream.
41
ObjectInputStream
ObjectInputStream extends InputStream and implements
ObjectInput and ObjectStreamConstants.
ObjectStreamConstants contains the constants to support
ObjectInputStream/ObjectOutputStream.
42
ObjectOutputStream
ObjectOutputStream extends OutputStream and
implements ObjectOutput and ObjectStreamConstants.
43
Using Object Streams
You may wrap an ObjectInputStream/ObjectOutputStream on any
InputStream/OutputStream using the following constructors:
// Create an ObjectInputStream
public ObjectInputStream(InputStream in)
// Create an ObjectOutputStream
public ObjectOutputStream(OutputStream out)
44
Serialization and Deserialization in Java
• Serialization is a process of converting an object into a sequence of
bytes which can be persisted to a disk or database or can be sent
through streams.
• Deserialization is the process of reconstructing the object from the
serialized state.
• It is the reverse process of creating an object from sequence of bytes.
• An ObjectInputStream class deserializes objects and primitive data
written using an ObjectOutputStream.
• The ObjectOutputStream class is used to write primitive data types
and Java objects to sequence of bytes.
• Only objects that support the java.io.Serializable interface can be
written to streams.
45
Example: Serializable program
import java.io.Serializable;
import java.io.*;
public class Student implements Serializable{
int id;
String name;
public Student(int id, String name) {
this.id = id;
this.name = name;
}
}
class Persist{
public static void main(String args[])throws Exception{
Student s1 =new Student(211,"ravi");
FileOutputStream fout=new FileOutputStream("file.txt");
ObjectOutputStream out=new ObjectOutputStream(fout);
out.writeObject(s1);
out.flush();
System.out.println("success");
}
} 46
Example: Deserializable program
import java.io.*;
public class Depersist{
public static void main(String args[])throws Exception{
FileInputStream input = new
FileInputStream("file.txt");
ObjectInputStream in=new ObjectInputStream(input);
Student s=(Student)in.readObject();
System.out.println(s.id+" "+s.name);
in.close();
}
}
47
2. Character I/O Streams
• Character Stream is an input and output data as a
sequence of characters.
• Java Byte streams are used to perform input and
output of 8-bit bytes, whereas Java Character
streams are used to perform input and output for
16-bit Unicode.
• All character stream classes are also descended
from two abstract classes Read and Writer.
• The most frequently used character stream
classes are: FileReader and FileWriter.
48
2. Character I/O Streams
49
3. Standard I/O Streams
• All the programming languages provide support for
standard I/O where the user's program can take input from a
keyboard and then produce an output on the computer
screen.
• Java provides the following three standard streams:
– Standard Input - This is used to feed the data to user's program
and usually a keyboard is used as standard input stream and
represented as System.in.
– Standard Output - This is used to output the data produced by
the user’s program and usually a computer screen is used for
standard output stream and represented as System.out.
– Standard Error - This is used to output the error data produced
by the user’s program and usually a computer screen is used for
standard error stream and represented as System.err. 50
The End!!
51