Telecooperation/RBG Technische Universität Darmstadt Copyrighted material; for TUD student use only Introduction to Computer Science I Topic 20: Streams.

Slides:



Advertisements
Similar presentations
A Guide to Advanced Java Faculty:Nguyen Ngoc Tu. 2 Operating System Application #1 Application #2 Java Virtual Machine #1 Local Memory Shared Memory Threads.
Advertisements

I/O Basics 12 January 2014Smitha N. Pai, CSE Dept.1.
1 Streams and Input/Output Files Part 2. 2 Files and Exceptions When creating files and performing I/O operations on them, the systems generates errors.
1 Streams and Input/Output Files Part 3. 2 Handling Primitive Data Types The basic input and output streams provide read/write methods that can be used.
1 Streams and Input/Output Files Part I. 2 Introduction So far we have used variables and arrays for storing data inside the programs. This approach poses.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 24.1 Test-Driving the Ticket Information Application.
Chapter 19 Binary I/O.
Jan Java I/O Yangjun Chen Dept. Business Computing University of Winnipeg.
Introduction to Java 2 Programming Lecture 7 IO, Files, and URLs.
Lecture 15: I/O and Parsing
The Package Statement Group related interfaces and classes together Purpose: encapsulation and reduces name conflicts –private package classes not visible.
Java File I/O. File I/O is important! Being able to write and read from files is necessary and is also one common practice of a programmer. Examples include.
MOD III. Input / Output Streams Byte streams Programs use byte streams to perform input and output of 8-bit bytes. This Stream handles the 8-bit.
Streams Dwight Deugo Nesa Matic Portions of the notes for this lecture include excerpts from.
III. Streams. Introduction Often a program needs to bring in information from an external source or to send out information to an external destination.
COMP201 Java Programming Topic 5: Input and Output Reading: Chapter 12.
Standard input, output and error. Lecture Under Construction.
Geoff Holmes Overview IO Zoo Stream I/O File I/O Buffering Random-Access Text Streams Examples Serialization Java IO – programs that start with import.
Java I/O and Java Networking (Client Side) Yoshi.
File I/O in Java CS 311, Winter File Basics Recall that a file is block structured. What does this mean? What happens when an application opens.
CS102--Object Oriented Programming Lecture 14: – File I/O BufferedReader The File class Write to /read from Binary files Copyright © 2008 Xiaoyan Li.
Exceptions and IO Dr. Andrew Wallace PhD BEng(hons) EurIng
Java I/O Input: information brought to program from an external source
CS203 Programming with Data Structures Input and Output California State University, Los Angeles.
Java How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.
Prepared by : A.Alzubair Hassan Kassala university Dept. Computer Science Lecture 2 I/O Streams 1.
Chapter 17 Input and Output F Stream Classes F Processing External Files F Data Streams F Print Streams F Buffered Streams  Use JFileChooser F Text Input.
Streams Reading: 2 nd Ed: , rd Ed: 11.1, 19.1, 19.4
Chapter 9 1 Chapter 9 – Part 1 l Overview of Streams and File I/O l Text File I/O l Binary File I/O l File Objects and File Names Streams and File I/O.
Java How to Program, 8/e © by Pearson Education, Inc. All Rights Reserved.
Based on OOP with Java, by David J. Barnes Input-Output1 The java.io Package 4 Text files Reader and Writer classes 4 Byte stream files InputStream, FileInputStream,
OOP with Java, David J. Barnes Input-Output1 A complex issue in programming language design. The interface to the outside world. –Differences must be accommodated.
JAVA I/O © EnhanceEdu, IIIT Hyderabad. Contents 3/29/2010EnhanceEdu, IIIT - H 2  Command Line I/O  File Class  Streams  Byte Streams [Low level and.
MIT AITI 2003 Lecture 15 Streams Input and Output data from/to other sources.
1 Week 12 l Overview of Streams and File I/O l Text File I/O Streams and File I/O.
Java Programming: Advanced Topics 1 Input/Output and Serialization Chapter 3.
Java Input/Output CSE301 University of Sunderland Harry Erwin, PhD Half Lecture.
Two Ways to Store Data in a File  Text format  Binary format.
Introduction to Computation and Problem Solving Class 29: Introduction to Streams Prof. Steven R. Lerman and Dr. V. Judson Harward.
A stream is a sequence of data. A stream is a flowing sequence of characters.
1 Software 1 Java I/O. 2 The java.io package The java.io package provides: Classes for reading input Classes for writing output Classes for manipulating.
CIS Intro to JAVA Lecture Notes Set 6 2-June-05.
– Advanced Programming P ROGRAMMING IN Lecture 22 Input and Output System.
Chapter 15: Input and Output F Stream Classes F Processing External Files F Data Streams F Print Streams F Buffered Streams F Parsing Text Files F Random.
Chapter 15: Input and Output
Company Input/Output Stream –. Input/Output Stream Data Program Input Stream Output Stream.
I/O Basics 26 January Aside from print( ) and println( ), none of the I/O methods have been used significantly. The reason is simple: most real.
Exception Handling, Reading and Writing in Files, Serialization, Exceptions, Files, Streams, File Readers and Writers, Serializable SoftUni Team Technical.
I/O Basics Java does provide strong, flexible support for I/O related to files and networks. Java’s console based interaction is limited since in real.
UMass Lowell Computer Science Java and Distributed Computing Prof. Karen Daniels Fall, 2000 Lecture 13 Java Fundamentals File I/O Serializing an.
1 Putting Streams to use. 2 Stream Zoo C++ gives you istream, ostream, iostream, ifstream, ofstream, fstream, wistream, wifstream, istrsteam… (18) Java.
Java Input / Output l a modular approach to input/output: - different stream objects are connected/wrapped to handle I/O l a data stream object: a flow.
Java Programming: Advanced Topics 1 Input/Output and Serialization.
1 Input-Output A complex issue in programming language design. The interface to the outside world. –Differences must be accommodated as transparently as.
CS202 Java Object Oriented Programming Input and Output Chengyu Sun California State University, Los Angeles.
Java IO Exploring the java.io package and living to talk about it.
The Java IO System Different kinds of IO Different kinds of operations
Files and Streams The material in this chapter is not tested on the AP CS exams.
Java Text I/O CS140 Dick Steflik. Reader Abstract super class for character based input Subclasses: – BufferedReader – CharArrayReader – FilterReader.
Chapter 17 Input and Output
Exception Handling, Reading and Writing in Files, Serialization,
Ch14 Files and Streams OBJECTIVES
Object Writing in files
I/O Basics.
Chapter 17 Binary I/O Dr. Clincy - Lecture.
Stream Oriented I/O Computer Programming II Dr. Tim Margush
Files and Streams in Java
CS 240 – Advanced Programming Concepts
David Davenport Spring 2005
Presentation transcript:

Telecooperation/RBG Technische Universität Darmstadt Copyrighted material; for TUD student use only Introduction to Computer Science I Topic 20: Streams and Input/Output Prof. Dr. Max Mühlhäuser Dr. Guido Rößling

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Outline Introduction to Input/Output Streams and Java Input/Output (I/O) Overview of Processing Streams Wrapping Streams and the Decorator Pattern User Defined Streams, StreamTokenizer and Random Access 2

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Input / Output: Motivation So far: –Program input data is either coded in the programs source code, or passed as parameters from the console define in Scheme Variable declaration and initialization in Java Actual arguments passed to functions in Scheme args parameters to main –Program output is shown on the display Problems: –Need to change the program in order to run it with different data –Closed world: No interactivity with the outside world No influence on the run is possible after the program starts –Results cannot be stored This lecture discusses other ways of input/output 3

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Input / Output (I/O) - Streams Other sources / sinks for program data / results –Keyboard entry (standard I/O), –Files on local machine ("file I/O") –Files/processes on the network ("network I/O") –Main memory ("memory I/O") To deal with all these sources/destinations uniformly, the concept of a data stream is introduced in Java –Input and output streams (I/O streams for short) Streams abstract from I/O devices –Hide details of the implementation and particularities of operating various I/O devices Keyboard, Files, Programs, Network, Memory, … –Provide unified interfaces for read/write data access –Java program talks to Java I/O stream objects 4

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 I/O-Streams In order to read data, an input stream is attached to a data source and the data is read element by element 5 In order to write data, an output stream is attached to a data sink and the data is written element by element

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Streams and delayed Lists The concept of streams is more general than just I/O We saw streams in Scheme –Delayed lists –We could create virtual lists –We could link transparently data with first and rest These ideas fit well with I/O –Input: on access to the next list item, read the input value –Output: on extension of the list, write the output value –Input stream delayed list without cons –Output stream delayed list without first/rest 6

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Predefined streams in java.io 7 Two orthogonal classifications: According to the type of data According to the structure of the stream

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Classification of streams According to the type of the data –character streams read / write char (16-bit Unicode character set) –byte streams read / write byte (8 bit): used to deal with binary data, e.g., images, sound, etc. According to stream structure –data streams: data is read/written directly from/to a concrete source/sink device –processing streams: data is read from/written to another stream Data is filtered, buffered, manipulated, etc. after reading, respectively before writing 8

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Hierarchy of Stream Classes in java.io 9 Character streams: –java.io.Reader/java.io.Writer provide the interface and a partial implementation for character input/output streams –Subclasses of Reader/Writer add/refine the implementation in Reader/Writer Byte streams: – java.io.InputStream/java.io.OutputStream provide the interface and a partial implementation for reading/writing bytes – All other byte streams are subclasses of InputStream/OutputStream

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Character Stream Classes (Examples) 10 Reader StringReader InputStreamReader FilterReader FileReader PushbackReader LineNumberReader BufferedReader PrintWriter StringWriter FilterWriter BufferedWriter Writer OutputStreamWriter FileWriter shadows indicate processing streams

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Byte Stream Classes (Examples) 11 InputStream OutputStream FileInputStream PipedInputStream FilterInputStream ByteArrayInputStream ObjectInputStream SequenceInputStream StringBufferInputStream LineNumberInputStream BufferedInputStream PushbackInputStream DataInputStream FileOutputStream PipedOutputStream ByteArrayOutputStream FilterOutputStream ObjectOutputStream PrintStream DataOutputStream BufferedOutputStream shadows indicate processing streams

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Data Streams: Overview 12 Type of DeviceCharacter StreamsByte Streams Main Memory Pipe File CharArrayReader, CharArrayWriter StringReader, StringWriter PipedReader, PipedWriter FileReader, FileWriter ByteArrayInputStream, ByteArrayOutputStream StringBufferInputStream PipedInputStream, PipedOutputStream FileInputStream, FileOutputStream CharArrayReader/CharArrayWriter ByteArrayInputStream/ByteArrayOutputStream – read from or write to an existing array in main memory StringReader / StringWriter, StringBufferInputStream – read from or write to Strings in main memory FileReader/FileWriter FileInputStream/FileOutputStream – read from or write to a file on disc

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Common patterns of I/O-streams Working with streams follows a pattern, independent of the data type, source, or sink Reading Open stream: implicit by creation Read data as long as data is needed and available Close stream After reading/writing, you should close() the stream! Writing Open stream Write data as long as required Close stream 13

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Common interfaces of I/O-streams 14 Use I/O Streams only via common Interface Information hiding via subtype polymorphism InputStream public int read() public int read(byte[] bbuf) public int read(byte[] bbuf, int offset, int len) Reader public int read() public int read(char[] cbuf) public int read(char[] cbuf, int offset, int len) OutputStream public int write(int b) public int write(byte[] bbuf) public int write(byte[] bbuf, int offset, int len) Writer public int write(int c) public int write(char[] cbuf) public int write(char[] cbuf, int offset, int len)

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 The java.io.Reader class public abstract int read(char[] c) throws IOException –reads the next Unicode characters into an array ( c ) –Returns the number of characters read, or -1 if the end of the stream has been reached ("EOF, End of File) –Any other problem causes an IOException, e.g., stream already closed, network connection lost, For more details, see the API specification public int read(char[] c) throws IOException public long skip(long n) throws IOException public void reset() throws IOException public int close() throws IOException...

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Java Documentation 16

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Java Documentation 17

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 File Streams File streams represent I/O streams from and to files in the file system: –FileReader for reading and FileWriter for writing character-wise from/to a file –Similarly FileInputStream, FileOutputStream for byte-wise reading/writing File streams are created by providing the source / destination file by means of: – A file name ( String ) – A file object ( java.io.File ) – A file descriptor ( java.io.FileDescriptor ) 18

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Class java.io.FileReader 19 Example: print file contents to screen (as int) and write 'a' to 'z' to a file import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; public class ReadWriteFile { // constructor etc. public void readFrom(String fileName) throws IOException { FileReader in = new FileReader(fileName); int b; while ((b = in.read()) != -1) System.out.print(b); in.close(); } public void writeAToZ(String filename) throws IOException { FileWriter out = new FileWriter(filename); for (char c = 'a'; c <= 'z'; c++) out.write(c); out.close(); } // main() etc. }

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Outline Introduction to Input/Output Streams and Java Input/Output (I/O) Overview of Processing Streams Wrapping Streams and the Decorator Pattern User Defined Streams, Stream Tokenizer and Random Access 20

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Processing Streams A processing stream contains another (data or processing) stream –The latter is used as a data source or data sink, respectively Data might be transformed or functionality added –data buffering –counting lines –converting bytes and chars –compression – … 21 data drain processing stream data source device data stream

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Processing Streams: Overview 22 processcharacter streamsbyte streams filtering buffering byte / char conversion counting datatype handling undoing printing FilterReader, FilterWriter FilterInputStream, FilterOutputStream BufferedReader, BufferedWriter BufferedInputStream, BufferedInputStream InputStreamReader, OutputStreamWriter LineNumberReader LineNumberInputStream DataInputStream, DataOutputStream PushbackReader PushbackInputStream PrintWriter PrintStream byte char char byte

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Roots of processing streams FilterReader/-Writer and FilterInputStream/FilterOutputStream are general super-classes for every processing stream They encapsulate an internal stream in Default implementations of an operation op : pass on op() to the underlying stream concrete filter (sub-)classes refine this functionality 23

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Java Documentation 24

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Buffered Streams A buffered stream temporarily stores data from another stream in an internal buffer Reading from a buffered stream fills the buffer when it is empty –Further "read"-operations will access the buffer without reading from the attached stream –When the buffer is empty, additional data will be read from the underlying stream Writing to a buffered stream fills the buffer before the attached data sink is written to –The buffer is also emptied if the stream is flushed explicitly ( flush() ) or closed ( close() ) 25

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Buffered Streams BufferedReader and BufferedWriter –Subclasses of Reader/Writer, respectively BufferedInputStream and BufferedOutputStream –Subclasses of FilterInputStream / FilterOutputStream 26

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Buffered Streams 27 Data Sink Program BufferedWriter b write bbuf write bbuf write bbuf flush

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Buffered Streams: Performance 28 Reading a file of 2.5MB (x=buffer size, y=time [ms]) Buffer sizeTime[ms]

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Data Streams 29 A data stream lets an application read/write primitive Java data types from/to an underlying I/O stream in a machine-independent way. An application uses a DataOutputStream to write data that can later be read by a DataInputStream. FilterInputStream DataInputStream readBoolean(): boolean readByte(): byte readShort() : short readChar() : char readInt() : int readFloat() : float FilterOutputStream DataOutputStream writeBoolean(boolean) : void writeByte(byte) : void writeShort(short) : void writeChar(char) : void writeInt(int) : void writeFloat(float) : void > DataInput > DataOutput

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Data Streams: Example 30 import java.io.FileOutputStream; import java.io.DataOutputStream; import java.io.IOException; public class DataStreamExample { String fileName = // some name; // some methods public void writeData() throws IOException { FileOutputStream fos = new FileOutputStream(filename); DataOutputStream out = new DataOutputStream(fos); out.writeInt(9); out.writeDouble(Math.PI); out.writeBoolean(true); out.close(); } // other methods public void readData() throws IOException { FileInputStream fis = new FileInputStream(fileName); DataInputStream in = new DataInputStream(fis); int i = in.readInt(); double d = in.readDouble(); boolean b = in.readBoolean(); in.close(); System.out.println("Read "+ i + ", " + d + ", and " + b+ "."); } }

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Standard-I/O Package java.lang contains the class System with the following class variables: static in standard input (keyboard) static out standard output (screen) static err standard error messages(screen) System.in yields an object of type InputStream –enables to read() characters (bytes) from the keyboard System.out, System.err are of type PrintStream –offer print(...) and println(...) to output data to the screen 31

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 PrintStream 32 FilterOutputStream PrintStream print(boolean) : void print(double) : void print(char) : void print(double) : void print(float) : void... println(Object): void println(String): void... Adds the ability to conveniently print user-readable representations of various data values Never throws an IOException –Exceptional situations set an internal flag that can be tested via the checkError method All characters printed by a PrintStream are converted into bytes using the platform's default character encoding –PrintWriter should be used in situations that require writing characters rather than bytes.

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Outline Introduction to Input/Output Streams and Java Input/Output (I/O) Overview of Processing Streams Wrapping Streams and the Decorator Pattern User Defined Streams, StreamTokenizer and Random Access 33

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 The Architecture of Java Streams Streams can be wrapped around each other –Abstraction layers, where underlying primitive streams are used by the enclosing (higher, more comfortable) streams 34 Data sink, e.g. file FileOutputStream BufferedOutputStream ZipOutputStream // create a buffered compressed output stream to a file OutputStream out = new FileOutputStream(filename); out = new BufferedOutputStream(out); out = new ZipOutputStream(out); //... more features can be dynamically added // the stream features are not visible for clients

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 The Architecture of Java Streams The technique that lets us combine streams at runtime is of more general interest. –A general way to extend objects with new features dynamically In software technology, such kind of techniques are documented as design patterns. –Reusable, documented design ideas –More in the lecture SE Design The technique underlying the architecture of Java I/O streams is known as the Decorator Pattern. 35

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Outline Introduction to Input/Output Streams and Java Input/Output (I/O) Overview of Processing Streams Wrapping Streams and the Decorator Pattern User Defined Streams, Stream Tokenizer and Random Access 36

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 User-Defined Processing Streams Sometimes it is useful to define streams that process (e.g., filtering, statistics, production of information chunks) data from other streams Best implemented by inheriting from FilterReader/FilterInputStream or FilterWriter/FilterOutputStream, respectively In the following example, a process stream filters out all lines which do not contain a certain substring Unix "grep" command 37

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 User-Defined Processing Streams 38 import java.io.BufferedReader; import java.io.FilterReader; import java.io.IOException; class GrepReader extends FilterReader { String substring; BufferedReader in; GrepReader(BufferedReader reader, String pattern) { super(reader); in = reader; substring = pattern; } // return the next line containing the search pattern String readLine() throws IOException { String line; while (((line = in.readLine()) != null) && (line.indexOf(substring) == -1)) ; return line; } }

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 User-Defined Processing Streams import java.io.*; public class Grep { public static void main(String[] args) { if ((args.length == 0) || (args.length > 2)) { System.out.println("Usage: java Grep [ ]"); System.exit(0); } try { Reader d; if (args.length == 2) d = new FileReader(args[1]); else d = new InputStreamReader(System.in); GrepReader g = new GrepReader(new BufferedReader(d), args[0]); String line; while ((line = g.readLine()) != null) System.out.println(line); g.close(); } catch (IOException e) { System.err.println(e); } } } 39 stream being searched pattern to look for

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Random Access Until now, we have only considered sequential streams that could only be read or written sequentially Sequential streams are a good fit for sequential storage media, e.g. magnetic tapes Random Access Files allow for non-sequential access (random access) to the contents of a file 40

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Motivating Example for Random Access How to extract one file? 41 Let us regard the file format of a ZIP archive: –ZIP archives contain files and are usually compressed to save disk space –Apart from the files, there is an additional entry at the end of the file, the so-called dir-entry (for directory) –The dir-entry is used to keep track of which files are contained and where – within the archive – they begin

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Motivating Example for Random Access Extracting a file using a sequential stream: –Search the whole archive until the file is found –Extract the file On average: half of the entries are searched… Extracting a file using a random access stream: –Jump to the directory & read the entry of the file –Jump to the recorded position of the file –Extract the file Only two entities (directory & file) need to be read This approach is far more efficient 42

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Random Access in Java 43 Realized by the class RandomAccessFile Can be used for reading and writingimplements the interfaces DataInput and DataOutput Similar to FileInputStream and FileOutputStream, you open a RandomAccessFile on a file and pass a file name or a File object as a parameter Additionally, you have to pass a parameter to specify whether the file is opened for read-only or also for writing –You have to be able to read a file to be able to write to it

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 The Class RandomAccessFile Creation a RandomAccessFile for reading file random.txt: –new RandomAccessFile("random.txt", "r"); Creating a RandomAccessFile for reading and writing on random.txt: –new RandomAccessFile("random.txt", "rw"); Afterwards, read and write operations may be used to read and write data from/to the file 44

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 The Class RandomAccessFile RandomAccessFile supports a file pointer: points to the current position in a file Upon creation, the pointer is 0, i.e., beginning of the file Calls to read and write operations automatically move the file pointer by the number of read, respectively written bytes 45 RandomAccessFile also supports positioning operations int skipBytes(int n) throws IOException moves read/write position by n bytes (relative positioning) native void seek(long pos) throws IOException positions read/write position right before pos (absolute positioning) native long getFilePointer() throws IOException returns the current read/write position

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Stream Tokenizer java.io.StreamTokenizer supports the generation of tokens out of character sequences A token is obtained by calling nextToken () –Ignores Whitespace User can define what is to be regarded as whitespace –The type of the token read in is stored in the attribute ttype The token types are explained on the next slide 46

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 StreamTokenizer : Token Types Basic token types: –StreamTokenizer.TT_NUMBER – number scanned; the number is stored in nval as a double –StreamTokenizer.TT_WORD – a composed word is recognized which is stored in sval –StreamTokenizer.TT_EOL – end of line, if the tokenizer is configured to recognize EOL as a token ( eolIsSignificant(true) ) –StreamTokenizer.TT_EOF – end of file –Any other value is an encoding of the character read in 47

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Customizing StreamTokenizer public void wordChars(int low, int hi) –Defines what is to be regarded as a word –All characters in the interval [low, hi] are "word parts public void whitespaceChars(int low, int hi) –Defines whitespace –All characters in the interval [low, hi] are "space" characters public void eolIsSignificant(boolean flag) –Defines whether the end of line character is of interest public void quoteChar(char c) –Defines quote character See the API documentation for more features… 48

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 StreamTokenizer : Example Read a list of tea data with the following format: –Each line contains data for one type of tea, i.e., the end of line token is of relevance –Data items per tea type (separated by spaces) Tea name in quotes Number of seconds required Number of recommended tea spoons per liter What would be a complex program without further support, is easily written with the help of StreamTokenizer 49 "Ali Baba's 40 scents" "Asatsuyu" 90 7 "Generic Black Tea" "Caramel" "Ceylon Pekoe" "China Jasmin" "Chinese Love Dream" "One For All" "Cherry Cream" 120 6

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 StreamTokenizer Example void parseTeas(InputStream is) throws IOException { StreamTokenizer stok = new StreamTokenizer(is); stok.eolIsSignificant(true); // EOL is important! stok.quoteChar('\"'); // quote char int token = 0; String teaName = null; int nrSecs, nrSpoons; while ((token = stok.nextToken()) != StreamTokenizer.TT_EOF) { teaName = stok.sval; // 1. token (name) token = stok.nextToken(); nrSecs = (int)stok.nval; // 2. (secs) token = stok.nextToken(); nrSpoons = (int)stok.nval; // 3. (spoons) token = stok.nextToken(); // consume EOL System.out.println(teaName + "=>" + nrSpoons + " spoons, seconds: " + nrSecs); } } 50 Normally, you should check the type actually read in before assigning it!

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 Scanner Since Java 1.5, the Scanner class can be used for parsing A Scanner can be opened on a Stream, file, … –Typical use: Scanner sc = new Scanner(System.in); The class offers many helpful methods, such as…: –String next (); // returns the next token –x nextX (); // for x = byte, double, float, int, long, short, Line Throws InputMismatchException if the type is not found –boolean hasNextX (); // same x as above Checks if the next element would match type X –You can redefine the delimiter, even to words –Additionally, regular expressions can be used for matching Check the API documentation for more information 51

Dr. G. Rößling Prof. Dr. M. Mühlhäuser RBG / Telekooperation © Introduction to Computer Science I: T20 What else? Encrypted files, compressed files, files sent over internet connections,... Exceptions! All I/O involves exceptions! –See part T16 for information on handling exceptions 52 try { statements involving I/O } catch (IOException e) { e.printStackTrace(); }