阅读(4232) (9)

鸿蒙OS DataOutput

2022-10-17 09:33:20 更新

DataOutput

public interface DataOutput

DataOutput 接口提供将数据从任何 Java 原始类型转换为一系列字节并将这些字节写入二进制流。 还有一种工具可以将字符串转换为修改后的 UTF-8 格式并写入生成的一系列字节。

对于此接口中所有写入字节的方法,通常情况下,如果由于某种原因无法写入字节,则会抛出 IOException。

Since:

JDK1.0

方法总结

修饰符和类型 方法 描述
void write(byte[] b) 将数组 b 中的所有字节写入输出流。
void write(byte[] b, int off, int len) 按顺序将数组 b 中的 len 个字节写入输出流。
void write(int b) 将参数 b 的 8 个低位写入输出流。
void writeBoolean(boolean v) 将布尔值写入此输出流。
void writeByte(int v) 将参数 v 的 8 个低位写入输出流。
void writeBytes(String s) 将字符串写入输出流。
void writeChar(int v) 将一个由两个字节组成的 char 值写入输出流。
void writeChars(String s) 将字符串 s 中的每个字符按顺序写入输出流,每个字符两个字节。
void writeDouble(double v) 将包含八个字节的双精度值写入输出流。
void writeFloat(float v) 将一个由四个字节组成的浮点值写入输出流。
void writeInt(int v) 将一个由四个字节组成的 int 值写入输出流。
void writeLong(long v) 将一个由 8 个字节组成的 long 值写入输出流。
void writeShort(int v) 将两个字节写入输出流以表示参数的值。
void writeUTF(String s) 将两个字节的长度信息写入输出流,然后是字符串 s 中每个字符的修改后的 UTF-8 表示。

方法详情

write

void write(int b) throws IOException

将参数 b 的 8 个低位写入输出流。 b 的高 24 位被忽略。

参数:

参数名称 参数描述
b 要写入的字节。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

write

void write(byte[] b) throws IOException

将数组 b 中的所有字节写入输出流。 如果 b 为 null,则抛出 NullPointerException。 如果 b.length 为零,则不写入任何字节。 否则,先写入字节 b[0],然后写入 b[1],以此类推; 最后写入的字节是 b[b.length-1]。

参数:

参数名称 参数描述
b 数据。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

write

void write(byte[] b, int off, int len) throws IOException

按顺序将数组 b 中的 len 个字节写入输出流。 如果 b 为 null,则抛出 NullPointerException。 如果 off 为负数,或 len 为负数,或 off+len 大于数组 b 的长度,则抛出 IndexOutOfBoundsException。 如果 len 为零,则不写入任何字节。 否则,先写入字节b[off],再写入b[off+1],以此类推; 最后写入的字节是 b[off+len-1]。

参数:

参数名称 参数描述
b 数据。
off 数据中的起始偏移量。
len 要写入的字节数。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeBoolean

void writeBoolean(boolean v) throws IOException

将布尔值写入此输出流。 如果参数 v 为 true,则写入值(字节)1; 如果 v 为 false,则写入值(字节)0。 该方法写入的字节可以被接口DataInput的readBoolean方法读取,然后返回一个等于v的布尔值。

参数:

参数名称 参数描述
v 要写入的布尔值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeByte

void writeByte(int v) throws IOException

将参数 v 的 8 个低位写入输出流。 v 的 24 个高位被忽略。 (这意味着 writeByte 与写入整数参数的操作完全相同。)此方法写入的字节可以由接口 DataInput 的 readByte 方法读取,然后返回等于 (byte)v 的字节。

参数:

参数名称 参数描述
v 要写入的字节值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeShort

void writeShort(int v) throws IOException

将两个字节写入输出流以表示参数的值。 要写入的字节值按所示顺序为:

 (byte)(0xff & (v >> 8))
 (byte)(0xff & v)

此方法写入的字节可能会被接口 DataInput 的 readShort 方法读取,然后该方法将返回一个等于 (short)v 的short。

参数:

参数名称 参数描述
v 要写入的短值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeChar

void writeChar(int v) throws IOException

将一个由两个字节组成的 char 值写入输出流。 要写入的字节值按所示顺序为:

 (byte)(0xff & (v >> 8))
 (byte)(0xff & v)

该方法写入的字节可以被接口 DataInput 的 readChar 方法读取,然后返回一个等于 (char)v 的字符。

参数:

参数名称 参数描述
v 要写入的 char 值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeInt

void writeInt(int v) throws IOException

将一个由四个字节组成的 int 值写入输出流。 要写入的字节值按所示顺序为:

 (byte)(0xff & (v >> 24))
 (byte)(0xff & (v >> 16))
 (byte)(0xff & (v >>  8))
 (byte)(0xff & v)

此方法写入的字节可以由接口 DataInput 的 readInt 方法读取,然后返回一个等于 v 的 int。

参数:

参数名称 参数描述
v 要写入的 int 值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeLong

void writeLong(long v) throws IOException

将一个由 8 个字节组成的 long 值写入输出流。 要写入的字节值按所示顺序为:

 (byte)(0xff & (v >> 56))
 (byte)(0xff & (v >> 48))
 (byte)(0xff & (v >> 40))
 (byte)(0xff & (v >> 32))
 (byte)(0xff & (v >> 24))
 (byte)(0xff & (v >> 16))
 (byte)(0xff & (v >>  8))
 (byte)(0xff & v)

该方法写入的字节可以被接口 DataInput 的 readLong 方法读取,然后返回一个等于 v 的 long。

参数:

参数名称 参数描述
v 要写入的 long 值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeFloat

void writeFloat(float v) throws IOException

将一个由四个字节组成的浮点值写入输出流。 就像它首先完全按照 Float.floatToIntBits 方法的方式将此浮点值转换为一个 int,然后按照 writeInt 方法的完全一样的方式写入 int 值。 该方法写入的字节可能会被接口 DataInput 的 readFloat 方法读取,然后返回一个等于 v 的浮点数。

参数:

参数名称 参数描述
v 要写入的浮点值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeDouble

void writeDouble(double v) throws IOException

将包含八个字节的双精度值写入输出流。 就像它首先完全按照 Double.doubleToLongBits 方法的方式将此 double 值转换为 long 值,然后按照 writeLong 方法的方式写入 long 值一样。 这个方法写入的字节可以被接口DataInput的readDouble方法读取,然后返回一个等于v的double。

参数:

参数名称 参数描述
v 要写入的双精度值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeBytes

void writeBytes(String s) throws IOException

将字符串写入输出流。 对于字符串 s 中的每个字符,按顺序将一个字节写入输出流。 如果 s 为 null,则抛出 NullPointerException。

如果 s.length 为零,则不写入任何字节。 否则先写字符s[0],再写s[1],以此类推; 最后写入的字符是 s[s.length-1]。 对于每个字符,以 writeByte 方法的方式写入一个字节,即低位字节。 忽略字符串中每个字符的高八位。

参数:

参数名称 参数描述
s 要写入的字节串。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeChars

void writeChars(String s) throws IOException

将字符串 s 中的每个字符按顺序写入输出流,每个字符两个字节。 如果 s 为 null,则抛出 NullPointerException。 如果 s.length 为零,则不写入任何字符。 否则先写字符s[0],再写s[1],以此类推; 最后写入的字符是 s[s.length-1]。 对于每个字符,实际上写入了两个字节,首先是高位字节,这与 writeChar 方法的方式完全相同。

参数:

参数名称 参数描述
s 要写入的字符串值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。

writeUTF

void writeUTF(String s) throws IOException

将两个字节的长度信息写入输出流,然后是字符串 s 中每个字符的修改后的 UTF-8 表示。 如果 s 为 null,则抛出 NullPointerException。 根据字符的值,字符串 s 中的每个字符都转换为一组一个、两个或三个字节。

如果字符 c 在 \u0001 到 \u007f 的范围内,它由一个字节表示:

(byte)c 

如果字符 c 是 \u0000 或在 \u0080 到 \u07ff 范围内,则它由两个字节表示,按所示顺序写入:

 (byte)(0xc0 | (0x1f & (c >> 6)))
 (byte)(0x80 | (0x3f & c))

如果字符 c 在 \u0800 到 uffff 范围内,则它由三个字节表示,按所示顺序写入:

 (byte)(0xe0 | (0x0f & (c >> 12)))
 (byte)(0x80 | (0x3f & (c >>  6)))
 (byte)(0x80 | (0x3f & c))

首先,计算表示 s 的所有字符所需的总字节数。 如果此数字大于 65535,则抛出 UTFDataFormatException。 否则,这个长度完全按照 writeShort 方法的方式写入输出流; 在此之后,写入字符串 s 中每个字符的一、二或三字节表示。

该方法写入的字节可以被接口 DataInput 的 readUTF 方法读取,然后返回一个等于 s 的字符串。

参数:

参数名称 参数描述
s 要写入的字符串值。

Throws:

Throw名称 Throw描述
IOException 如果发生 I/O 错误。