Prev Class | Next Class | Frames | No Frames |
Summary: Nested | Field | Method | Constr | Detail: Nested | Field | Method | Constr |
java.lang.Object
java.io.OutputStream
java.io.FilterOutputStream
java.io.DataOutputStream
OutputStream
in a portable way. Data written to
a stream using this class can be read back in using the
DataInputStream
class on any platform.
DataInputStream
Field Summary | |
protected int |
|
Fields inherited from class java.io.FilterOutputStream | |
out |
Constructor Summary | |
|
Method Summary | |
void |
|
int |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
Methods inherited from class java.lang.Object | |
clone , equals , extends Object> getClass , finalize , hashCode , notify , notifyAll , toString , wait , wait , wait |
protected int written
This is the total number of bytes that have been written to the stream by this object instance.
public DataOutputStream(OutputStream out)
This method initializes an instance ofDataOutputStream
to write its data to the specified underlyingOutputStream
- Parameters:
out
- The subordinateOutputStream
to which this object will write
public void flush() throws IOException
This method flushes any unwritten bytes to the underlying stream.
- Overrides:
- flush in interface FilterOutputStream
- Throws:
IOException
- If an error occurs.
public final int size()
This method returns the total number of bytes that have been written to the underlying output stream so far. This is the value of thewritten
instance variable
- Returns:
- The number of bytes written to the stream.
public void write(byte[] buf, int offset, int len) throws IOException
This method writeslen
bytes from the specified byte arraybuf
starting at positionoffset
into the buffer to the underlying output stream.
- Specified by:
- write in interface DataOutput
- Overrides:
- write in interface FilterOutputStream
- Parameters:
buf
- The byte array to write from.offset
- The index into the byte array to start writing from.len
- The number of bytes to write.
- Throws:
IOException
- If an error occurs.
public void write(int value) throws IOException
This method writes the specified byte (passed as anint
) to the underlying output stream.
- Specified by:
- write in interface DataOutput
- Overrides:
- write in interface FilterOutputStream
- Parameters:
value
- Thebyte
to write, passed as anint
.
- Throws:
IOException
- If an error occurs.
public final void writeBoolean(boolean value) throws IOException
This method writes a Java boolean value to an output stream. Ifvalue
istrue
, a byte with the value of 1 will be written, otherwise a byte with the value of 0 will be written. The value written can be read using thereadBoolean
method inDataInput
.
- Specified by:
- writeBoolean in interface DataOutput
- Parameters:
value
- Theboolean
value to write to the stream
- Throws:
IOException
- If an error occurs
- See Also:
DataInput.readBoolean()
public final void writeByte(int value) throws IOException
This method writes a Java byte value to an output stream. The byte to be written will be in the lowest 8 bits of theint
value passed. The value written can be read using thereadByte
orreadUnsignedByte
methods inDataInput
.
- Specified by:
- writeByte in interface DataOutput
- Parameters:
value
- Thebyte
to write to the stream, passed as the low eight bits of anint
.
- Throws:
IOException
- If an error occurs
public final void writeBytes(String value) throws IOException
This method writes all the bytes in aString
out to the stream. One byte is written for each character in theString
. The high eight bits of each character are discarded, thus this method is inappropriate for completely representing Unicode characters.
- Specified by:
- writeBytes in interface DataOutput
- Parameters:
value
- TheString
to write to the stream
- Throws:
IOException
- If an error occurs
public final void writeChar(int value) throws IOException
This method writes a Java char value to an output stream. The char to be written will be in the lowest 16 bits of theint
value passed. These bytes will be written "big endian". That is, with the high byte written first in the following manner:
byte0 = (byte)((value & 0xFF00) >> 8);
byte1 = (byte)(value & 0x00FF);The value written can be read using the
readChar
method inDataInput
.
- Specified by:
- writeChar in interface DataOutput
- Parameters:
value
- Thechar
value to write, passed as anint
.
- Throws:
IOException
- If an error occurs
- See Also:
DataInput.readChar()
public final void writeChars(String value) throws IOException
This method writes all the characters of aString
to an output stream as an array ofchar
's. Each character is written using the method specified in thewriteChar
method.
- Specified by:
- writeChars in interface DataOutput
- Parameters:
value
- TheString
to write to the stream
- Throws:
IOException
- If an error occurs
- See Also:
writeChar(char)
public final void writeDouble(double value) throws IOException
This method writes a Javadouble
value to the stream. This value is written by first calling the methodDouble.doubleToLongBits
to retrieve anlong
representing the floating point number, then writing thislong
value to the stream exactly the same as thewriteLong()
method does. The value written can be read using thereadDouble
method inDataInput
.
- Specified by:
- writeDouble in interface DataOutput
- Parameters:
value
- Thedouble
value to write to the stream
- Throws:
IOException
- If an error occurs
public final void writeFloat(float value) throws IOException
This method writes a Javafloat
value to the stream. This value is written by first calling the methodFloat.floatToIntBits
to retrieve anint
representing the floating point number, then writing thisint
value to the stream exactly the same as thewriteInt()
method does. The value written can be read using thereadFloat
method inDataInput
.
- Specified by:
- writeFloat in interface DataOutput
- Parameters:
value
- Thefloat
value to write to the stream
- Throws:
IOException
- If an error occurs
public final void writeInt(int value) throws IOException
This method writes a Java int value to an output stream. The 4 bytes of the passed value will be written "big endian". That is, with the high byte written first in the following manner:
byte0 = (byte)((value & 0xFF000000) >> 24);
byte1 = (byte)((value & 0x00FF0000) >> 16);
byte2 = (byte)((value & 0x0000FF00) >> 8);
byte3 = (byte)(value & 0x000000FF);The value written can be read using the
readInt
method inDataInput
.
- Specified by:
- writeInt in interface DataOutput
- Parameters:
value
- Theint
value to write to the stream
- Throws:
IOException
- If an error occurs
- See Also:
DataInput.readInt()
public final void writeLong(long value) throws IOException
This method writes a Java long value to an output stream. The 8 bytes of the passed value will be written "big endian". That is, with the high byte written first in the following manner:
byte0 = (byte)((value & 0xFF00000000000000L) >> 56);
byte1 = (byte)((value & 0x00FF000000000000L) >> 48);
byte2 = (byte)((value & 0x0000FF0000000000L) >> 40);
byte3 = (byte)((value & 0x000000FF00000000L) >> 32);
byte4 = (byte)((value & 0x00000000FF000000L) >> 24);
byte5 = (byte)((value & 0x0000000000FF0000L) >> 16);
byte6 = (byte)((value & 0x000000000000FF00L) >> 8);
byte7 = (byte)(value & 0x00000000000000FFL);The value written can be read using the
readLong
method inDataInput
.
- Specified by:
- writeLong in interface DataOutput
- Parameters:
value
- Thelong
value to write to the stream
- Throws:
IOException
- If an error occurs
- See Also:
DataInput.readLong()
public final void writeShort(int value) throws IOException
This method writes a Java short value to an output stream. The char to be written will be in the lowest 16 bits of theint
value passed. These bytes will be written "big endian". That is, with the high byte written first in the following manner:
byte0 = (byte)((value & 0xFF00) >> 8);
byte1 = (byte)(value & 0x00FF);The value written can be read using the
readShort
andreadUnsignedShort
methods inDataInput
.
- Specified by:
- writeShort in interface DataOutput
- Parameters:
value
- Theshort
value to write to the stream, passed as anint
.
- Throws:
IOException
- If an error occurs
public final void writeUTF(String value) throws IOException
This method writes a JavaString
to the stream in a modified UTF-8 format. First, two bytes are written to the stream indicating the number of bytes to follow. Note that this is the number of bytes in the encodedString
not theString
length. Next come the encoded characters. Each character in theString
is encoded as either one, two or three bytes. For characters in the range of\u0001
to <\u007F>, one byte is used. The character value goes into bits 0-7 and bit eight is 0. For characters in the range of\u0080
to\u007FF
, two bytes are used. Bits 6-10 of the character value are encoded bits 0-4 of the first byte, with the high bytes having a value of "110". Bits 0-5 of the character value are stored in bits 0-5 of the second byte, with the high bits set to "10". This type of encoding is also done for the null character\u0000
. This eliminates any C style NUL character values in the output. All remaining characters are stored as three bytes. Bits 12-15 of the character value are stored in bits 0-3 of the first byte. The high bits of the first bytes are set to "1110". Bits 6-11 of the character value are stored in bits 0-5 of the second byte. The high bits of the second byte are set to "10". And bits 0-5 of the character value are stored in bits 0-5 of byte three, with the high bits of that byte set to "10". The value written can be read using thereadUTF
method inDataInput
.
- Specified by:
- writeUTF in interface DataOutput
- Parameters:
value
- TheString
to write to the output in UTF format
- Throws:
IOException
- If an error occurs
- See Also:
DataInput.readUTF()