0% found this document useful (0 votes)
35 views

Lecture 17 - IO

This document discusses input/output (IO) streams in Java. It covers opening and using streams to read from files and other sources. Some key points: - Streams provide a way to read from and write to various sources like files, networks, and memory in a consistent way. - Common stream classes include FileReader, BufferedReader, PrintWriter, and Scanner. - To use a stream, you open it, perform read/write operations, then close the stream to free resources. - The Scanner class can be used to read primitive types and strings from input sources like files or System.in. - Custom classes like LineReader are demonstrated to read entire lines of text

Uploaded by

Muhammad Tayyab
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
35 views

Lecture 17 - IO

This document discusses input/output (IO) streams in Java. It covers opening and using streams to read from files and other sources. Some key points: - Streams provide a way to read from and write to various sources like files, networks, and memory in a consistent way. - Common stream classes include FileReader, BufferedReader, PrintWriter, and Scanner. - To use a stream, you open it, perform read/write operations, then close the stream to free resources. - The Scanner class can be used to read primitive types and strings from input sources like files or System.in. - Custom classes like LineReader are demonstrated to read entire lines of text

Uploaded by

Muhammad Tayyab
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 54

SE241: Advanced Computer

Programming
Lecture # 17: IO
Muhammad Imran

1
Outline
•Streams
•Opening and Using Streams
•Reading Lines
•Using Scanner Class
•LineReader and LineWriter (Custom Class)
•PrintWriter Class
•Using JFileChooser
•Serialization
2
Streams
•All modern I/O is stream-based
•A stream is a connection to a source of data or to a
destination for data (sometimes both)
•An input stream may be associated with the keyboard
•An input stream or an output stream may be associated
with a file
•Different streams have different characteristics:
 A file has a definite length, and therefore an end
 Keyboard input has no specific end
3
Streams
•An abstraction of the continuous one-way data pipe
•Transfers a sequence of bytes to or from
 Disk files
 Network connections
 Memory
 Threads
•Streams are either byte-oriented or character-oriented
 An IOException may occur during any IO operation

4
• In Java, three streams are created automatically and attached with
the console.
 System.out: standard output stream
 System.in: standard input stream
 System.err: standard error stream

System.out.println("simple message");
System.err.println("error message");
int i=System.in.read();//returns ASCII code of 1st character
System.out.println((char)i);//will print the character

5
How to do I/O
import java.io.*;

• Open the stream


• Use the stream (read, write, or both)
• Close the stream

6
open
use
Why Java I/O is hard close

• Java I/O is very powerful, with an overwhelming number of options

• Any given kind of I/O is not particularly difficult

• The trick is to find your way through the maze of possibilities

7
open
use
Opening a stream close

• There is data external to your program that you want to get, or


you want to put data somewhere outside your program

• When you open a stream, you are making a connection to that


external place

• Once the connection is made, you forget about the external place
and just use the stream

8
open
Example of opening a stream use
close

• A FileReader is a used to connect to a file that will be used for input:

 FileReader fileReader = new FileReader(fileName);

• The fileName specifies where the (external) file is to be found

• You never use fileName again; instead, you use fileReader

9
open
use
Using a stream close

• Some streams can be used only for input, others only for output,
still others for both

• Using a stream means doing input from it or output to it

• But it’s not usually that simple--you need to manipulate the data
in some way as it comes in or goes out

10
open
use
Example of using a stream close

• int charAsInt;
charAsInt = fileReader.read( );

• The fileReader.read() method reads one character and returns


it as an integer, or -1 if there are no more characters to read

• The meaning of the integer depends on the file encoding (ASCII,


Unicode, other)

• You can cast from int to char:


char ch = (char)fileReader.read( );

11
open
use
Manipulating the input data close

• Reading characters as integers isn’t usually what you want to do

• A BufferedReader will convert integers to characters; it can also read whole lines

• The constructor for BufferedReader takes a FileReader parameter:


BufferedReader bufferedReader = new BufferedReader(fileReader);

12
open
use
Reading lines close

• String s;
s = bufferedReader.readLine( );

• A BufferedReader will return null if there is nothing more to read

13
open
use
Closing close

• A stream is an expensive resource


• There is a limit on the number of streams that you can have open
at one time
• You should not have more than one stream open on the same
file
• You must close a stream before you can open it again
• Always close your streams!

• Java will normally close your streams for you when your program
ends, but it isn’t good style to depend on this

14
Review: Scanner
• We've seen Scanner before
• The constructor takes an object of type
java.io.InputStream – stores information about the
connection between an input device and the computer or
program
 Example: System.in
• Recall – only associate one instance of Scanner with
System.in in your program
 Otherwise, get bugs

15
Reading Files
•The same applies for both console input and file input

•We can use a different version of a Scanner that takes a


File instead of System.in

•Everything works the same!

16
Reading Files
• To read from a disk file, construct a FileReader

• Then, use the FileReader to construct a Scanner object

FileReader rdr = newFileReader("input.txt");


Scanner fin = new Scanner(rdr);

17
Reading Files
• You can use File instead of FileReader
 Has an exists() method we can call to avoid
FileNotFoundException

File file = new File ("input.txt");


Scanner fin;
if(file.exists()){
fin = new Scanner(file);
} else {
//ask for another file
}

18
Reading Files
• Once we have a Scanner, we can use methods we already know:
 next, nextLine, nextInt, etc.

• Reads the information from the file instead of console

19
File Class
• java.io.File
 associated with an actual file on hard drive
 used to check file's status

• Constructors
 File(<full path>)
 File(<path>, <filename>)

• Methods
 exists()
 canRead(), canWrite()
 isFile(), isDirectory()

20
FileReader Class
•java.io.FileReader
 Associated with File object
 Translates data bytes from File object into a stream of
characters (much like InputStream vs.
InputStreamReader)
• Constructors
 FileReader( <File object> );

• Methods
 read(), readLine()
 close()

21
Simple Java I/O

Part II
LineReader and LineWriter

22
Text files
• Text (.txt) files are the simplest kind of files
 Text files can be used by many different programs

• Formatted text files (such as .doc files) also contain binary


formatting information

• Only programs that “know the secret code” can make sense of
formatted text files

• Compilers, in general, work only with text

23
My LineReader class

class LineReader {
BufferedReader bufferedReader;

LineReader(String fileName) {...}

String readLine( ) {...}

void close( ) {...}


}

24
Basics of the LineReader constructor
• Create a FileReader for the named file:
 FileReader fileReader =
new FileReader(fileName);

• Use it as input to a BufferedReader:


 BufferedReader bufferedReader =
new BufferedReader(fileReader);

• Use the BufferedReader; but first, we need to catch possible


Exceptions

25
The full LineReader constructor
LineReader(String fileName) {
FileReader fileReader = null;
try { fileReader = new FileReader(fileName); }
catch (FileNotFoundException e) {
System.err.println
("LineReader can’t find input file: " + fileName);
e.printStackTrace( );
}
bufferedReader = new BufferedReader(fileReader);
}

26
readLine

String readLine( ) {
try {
return bufferedReader.readLine( );
}
catch(IOException e) {
e.printStackTrace( );
}
return null;
}

27
close

void close() {
try {
bufferedReader.close( );
}
catch(IOException e) { }
}

28
How did I figure that out?
• I wanted to read lines from a file
• I thought there might be a suitable readSomething method, so I went to the
API Index
 Note: Capital letters are all alphabetized before lowercase in the Index

• I found a readLine method in several classes; the most promising was the
BufferedReader class
• The constructor for BufferedReader takes a Reader as an argument
• Reader is an abstract class, but it has several implementations, including
InputStreamReader
• FileReader is a subclass of InputStreamReader
• There is a constructor for FileReader that takes as its argument a (String)
file name

29
The LineWriter class

class LineWriter {
PrintWriter printWriter;

LineWriter(String fileName) {...}

void writeLine(String line) {...}

void close( ) {...}


}

30
The constructor for LineWriter
LineWriter(String fileName) {
try {
printWriter =
new PrintWriter(
new FileOutputStream(fileName),
true);
}
catch(Exception e) {
System.err.println("LineWriter can’t " +
"use output file: " + fileName);
}
}
31
Flushing the buffer
• When you put information into a buffered output stream, it goes
into a buffer

• The buffer may or may not be written out right away

• If your program crashes, you may not know how far it got before it
crashed

• Flushing the buffer forces the information to be written out

32
PrintWriter
• Buffers are automatically flushed when the program ends
normally
• Usually it is your responsibility to flush buffers if the program
does not end normally
• We can use a PrintWriter object to write to a file
• How do we use a PrintWriter object?
 Have we already seen one?

• PrintWriter can do the flushing for you


public PrintWriter(OutputStream out,boolean autoFlush)

33
Writing to a File using PrintWriter
• The out field of the System class is a PrintWriter object
associated with the console
 We will associate our PrintWriter with a file now

PrintWriter fout = new PrintWriter("output.txt");


fout.println(29.95);
fout.println(new Rectangle(5, 10, 15, 25));
fout.println("Hello, World!");

• This will print the exact same information as with


System.out (except to a file “output.txt”)!

34
writeLine (updated using PrintWriter)

void writeLine(String line) {


printWriter.println(line);
}

35
close

void close( ) {
printWriter.flush( );
try {
printWriter.close( );
}
catch(Exception e) { }
}

36
Java Input Review
CONSOLE:

Scanner stdin = new Scanner( System.in );

FILE:

Scanner inFile = new Scanner( new


FileReader(srcFileName ));

37
Java Output Review
• CONSOLE:

System.out.print("To the screen");

• FILE:

PrintWriter fout =
new PrintWriter(new File("output.txt");
fout.print("To a file");

38
Simple Java I/O

Part III
JFileChooser

39
About JFileChoosers
• The JFileChooser class displays a window from which the user
can select a file

• The dialog window is modal--the application cannot continue


until it is closed

• Applets cannot use a JFileChooser, because applets cannot


access files

40
Typical JFileChooser window

41
JFileChooser constructors
• JFileChooser()
 Creates a JFileChooser starting from the user’s directory

• JFileChooser(File currentDirectory)
 Constructs a JFileChooser using the given File as the path

• JFileChooser(String currentDirectoryPath)
 Constructs a JFileChooser using the given path

42
Useful JFileChooser methods I
• int showOpenDialog(Component enclosingJFrame);
 Asks for a file to read; returns a flag (see below)

• int showSaveDialog(Component enclosingJFrame);


 Asks where to save a file; returns a flag (see below)

• Returned flag value may be:


 JFileChooser.APPROVE_OPTION
 JFileChooser.CANCEL_OPTION
 JFileChooser.ERROR_OPTION

43
Useful JFileChooser methods II
•File getSelectedFile()
 showOpenDialog and showSaveDialog return a flag telling
what happened, but don’t return the selected file
 After we return from one of these methods, we have to ask the
JFileChooser what file was selected
 If we are saving a file, the File may not actually exist yet—that’s
OK, we still have a File object we can use

44
Using a File
• Assuming that we have successfully selected a File:

File file = chooser.getSelectedFile();


if (file != null) {
String fileName = file.getCanonicalPath();
FileReader fileReader = new FileReader(fileName);
BufferedReader reader = new BufferedReader(fileReader);
}

File file = chooser.getSelectedFile();


if (file != null) {
String fileName = file.getCanonicalPath();
FileOutputStream stream = new FileOutputStream(fileName);
writer = new PrintWriter(stream, true);
}
45
Simple Java I/O
Part IV
Serialization

46
Serialization
• You can also read and write objects to files

• Object I/O goes by the name of serialization

• Serialization in other languages can be very difficult, because


objects may contain references to other objects

• Java makes serialization (almost) easy

47
Conditions for serializability
•If an object is to be serialized:
 The class must be declared as public
 The class must implement Serializable
 The class must have a no-argument constructor
 All fields of the class must be serializable: either primitive
types or serializable objects

48
Implementing Serializable
• To “implement” an interface means to define all the methods
declared by that interface, but...

• The Serializable interface does not define any methods!


 Question: What possible use is there for an interface that does not
declare any methods?
 Answer: Serializable is used as flag to tell Java it needs to do extra work
with this class

49
Writing objects to a file
ObjectOutputStream objectOut =
new ObjectOutputStream(
new BufferedOutputStream(
new FileOutputStream(fileName)));

objectOut.writeObject(serializableObject);

objectOut.close( );

50
Reading objects from a file
ObjectInputStream objectIn =
new ObjectInputStream(
new BufferedInputStream(
new FileInputStream(fileName)));

myObject = (itsType)objectIn.readObject( );

objectIn.close( );

51
What have I left out?
• Encrypted files, compressed files, files sent over internet connections, ...

• Exceptions! All I/O involves Exceptions!


try { statements involving I/O }
catch (IOException e) {
e.printStackTrace ( );
}

52
try with resources
• try-with-resources, is an exception handling mechanism that can
automatically close resources once done!!

• You must open and use the resource within a Java try-with-
resources block.

• Resource are automatically closed, regardless of any exceptions


thrown from try-with-resources block.

53
Example:
public static void main (String[] args) throws IOException {

try(FileInputStream input = new FileInputStream("file.txt"))


{
int data = input.read();

while(data != -1){
System.out.print((char) data);
data = input.read();
}
}
}

54

You might also like