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

Java Streams

Java I/O streams allow data to be retrieved from input sources and sent to output destinations using streams. Streams provide a common abstraction for handling different physical devices. The core stream classes in Java are InputStream, OutputStream, Reader and Writer which handle byte and character streams respectively.

Uploaded by

kdhwani28
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
15 views

Java Streams

Java I/O streams allow data to be retrieved from input sources and sent to output destinations using streams. Streams provide a common abstraction for handling different physical devices. The core stream classes in Java are InputStream, OutputStream, Reader and Writer which handle byte and character streams respectively.

Uploaded by

kdhwani28
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 11

Java I/O streams

Java I/O
 Data is retrieved from an input source. The results of a
program are sent to an output destination.
 Devices are all handled by the same abstraction: the stream.
 A stream is a logical entity that either produces or consumes
information.
 A stream is linked to a physical device by the Java I/O
system.
 All streams behave in the same manner, even if the actual
physical devices they are linked to differ.
Java io classes
Java io interfaces
File
 File class does not operate on streams.
class FileDemo {
static void p(String s) {
System.out.println(s); File Name: COPYRIGHT
} Path: /java/COPYRIGHT
public static void main(String args[]) {
File f1 = new File("/java/COPYRIGHT"); Abs Path: /java/COPYRIGHT
p("File Name: " + f1.getName()); Parent: /java
p("Path: " + f1.getPath());
p("Abs Path: " + f1.getAbsolutePath());
exists
p("Parent: " + f1.getParent()); is writeable
p(f1.exists() ? "exists" : "does not exist");
is readable
p(f1.canWrite() ? "is writeable" : "is not writeable");
p(f1.canRead() ? "is readable" : "is not readable"); is not a directory
p("is " + (f1.isDirectory() ? "" : "not" + " a directory")); is normal file
p(f1.isFile() ? "is normal file" : "might be a named pipe");
p(f1.isAbsolute() ? "is absolute" : "is not absolute"); is absolute
p("File last modified: " + f1.lastModified()); File last modified: 812465204000
p("File size: " + f1.length() + " Bytes");
}
File size: 695 Bytes
}
The Stream Classes
 Java’s stream-based I/O is built upon four abstract classes:
InputStream, OutputStream, Reader, and Writer.
 InputStream and OutputStream are designed for byte
streams. Reader and Writer are designed for character
streams.
 The byte stream classes and the character stream classes form
separate hierarchies.
Streams
 InputStream is an abstract class that defines Java’s model of
streaming byte input. It implements the Closeable interface.
Most of the methods in this class will throw an
IOException on error conditions.
 OutputStream is an abstract class that defines streaming
byte output. It implements the Closeable and Flushable
interfaces. Most of the methods in this class return void and
throw an IOException in the case of errors.
Input stream
Outputstream
Print Writter
public class PrintWriterDemo {
public static void main(String args[]) {
PrintWriter pw = new PrintWriter(System.out, true);
pw.println("This is a string");
int i = -7;
pw.println(i);
double d = 4.5e-7;
pw.println(d);
}
}
The output:
This is a string
-7
4.5E-7
Input output
class CopyFile {
public static void main(String args[]) throws IOException } catch(ArrayIndexOutOfBoundsException e) {
{ System.out.println("Usage: CopyFile From To");
int i; return;
FileInputStream fin;
}
FileOutputStream fout;
try {
try {
do {
try {
fin = new FileInputStream(args[0]); i = fin.read();
} catch(FileNotFoundException e) { if(i != -1) fout.write(i);
System.out.println("Input File Not Found"); } while(i != -1);
return; } catch(IOException e) {
} System.out.println("File Error");
try {
}
fout = new FileOutputStream(args[1]);
fin.close();
} catch(FileNotFoundException e) {
System.out.println("Error Opening Output fout.close();
File"); }
return; }
}

You might also like