返回介绍

java.io 类 Writer

发布于 2019-10-04 09:50:53 字数 9908 浏览 960 评论 0 收藏 0

java.lang.Object
  └java.io.Writer
所有已实现的接口:
Closeable, Flushable, Appendable
直接已知子类:
BufferedWriter, CharArrayWriter, FilterWriter, OutputStreamWriter, PipedWriter, PrintWriter, StringWriter

public abstract class Writer
extends Object
 
implements Appendable, Closeable, Flushable
 

写入字符流的抽象类。子类必须实现的方法仅有 write(char[], int, int)、flush() 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。

从以下版本开始:
JDK1.1
另请参见:
Writer , BufferedWriter , CharArrayWriter , FilterWriter , OutputStreamWriter , FileWriter , PipedWriter , PrintWriter , StringWriter , Reader

字段摘要
protected Objectlock

用于同步针对此流的操作的对象。

构造方法摘要
protectedWriter()

创建一个新的字符流 writer,其关键部分将同步 writer 自身。

protectedWriter(Objectlock)

创建一个新的字符流 writer,其关键部分将同步给定的对象。

方法摘要
Writerappend(charc)

将指定字符追加到此 writer。

Writerappend(CharSequencecsq)

将指定字符序列追加到此 writer。

Writerappend(CharSequencecsq, intstart, intend)

将指定字符序列的子序列追加到此 writer.

abstract voidclose()

关闭此流,但要先刷新它。

abstract voidflush()

刷新此流。

voidwrite(char[]cbuf)

写入字符数组。

abstract voidwrite(char[]cbuf, intoff, intlen)

写入字符数组的某一部分。

voidwrite(intc)

写入单个字符。

voidwrite(Stringstr)

写入字符串。

voidwrite(Stringstr, intoff, intlen)

写入字符串的某一部分。

从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

字段详细信息

lock

protected Object lock
用于同步针对此流的操作的对象。为了提高效率,字符流对象可以使用其自身以外的对象来保护关键部分。因此,子类应使用此字段中的对象,而不是 this 或者同步的方法。

构造方法详细信息

Writer

protected Writer()
创建一个新的字符流 writer,其关键部分将同步 writer 自身。

Writer

protected Writer(Objectlock)
创建一个新的字符流 writer,其关键部分将同步给定的对象。
参数:
lock - 要同步的对象。

方法详细信息

write

public void write(intc)
           throws IOException
写入单个字符。要写入的字符包含在给定整数值的 16 个低位中,16 高位被忽略。

用于支持高效单字符输出的子类应重写此方法。

参数:
c - 指定要写入字符的 int。
抛出:
IOException - 如果发生 I/O 错误

write

public void write(char[]cbuf)
           throws IOException
写入字符数组。
参数:
cbuf - 要写入的字符数组
抛出:
IOException - 如果发生 I/O 错误

write

public abstract void write(char[]cbuf,
                           intoff,
                           intlen)
                    throws IOException
写入字符数组的某一部分。
参数:
cbuf - 字符数组
off - 开始写入字符处的偏移量
len - 要写入的字符数
抛出:
IOException - 如果发生 I/O 错误

write

public void write(Stringstr)
           throws IOException
写入字符串。
参数:
str - 要写入的字符串
抛出:
IOException - 如果发生 I/O 错误

write

public void write(Stringstr,
                  intoff,
                  intlen)
           throws IOException
写入字符串的某一部分。
参数:
str - 字符串
off - 相对初始写入字符的偏移量
len - 要写入的字符数
抛出:
IOException - 如果发生 I/O 错误

append

public Writer append(CharSequencecsq)
              throws IOException
将指定字符序列追加到此 writer。

out.append(csq) 形式的方法调用与以下调用具有完全相同的行为:

     out.write(csq.toString()) 

可能不会追加整个序列,这取决于针对字符序列 csqtoString 规范。例如,调用一个字符缓冲区的 toString 方法将返回一个子序列,其内容取决于缓冲区的位置和限制。

指定者:
接口 Appendable 中的 append
参数:
csq - 要追加的字符串序列。如果 csqnull ,则向此 writer 追加四个字符 "null"
返回:
此 writer
抛出:
IOException - 如果发生 I/O 错误
从以下版本开始:
1.5

append

public Writer append(CharSequencecsq,
                     intstart,
                     intend)
              throws IOException
将指定字符序列的子序列追加到此 writer. Appendable

csq 不为 null 时, out.append(csq, start, end) 形式的方法调用与以下调用具有完全相同的行为:

     out.write(csq.subSequence(start, end).toString()) 
指定者:
接口 Appendable 中的 append
参数:
csq - 要追加子序列的字符序列。如果 csqnull ,则追加四个字符 "null" ,就好像 csq 包含这些字符一样。
start - 子序列中第一个字符的索引
end - 子序列中最后一个字符后面的字符的索引
返回:
此 writer
抛出:
IndexOutOfBoundsException - 如果 startend 为负,而 start 大于 end 或者 end 大于 csq.length()
IOException - 如果发生 I/O 错误
从以下版本开始:
1.5

append

public Writer append(charc)
              throws IOException
将指定字符追加到此 writer。

out.append(c) 形式的方法调用与以下调用具有完全相同的行为:

     out.write(c) 
指定者:
接口 Appendable 中的 append
参数:
c - 要追加的 16 位字符
返回:
此 writer
抛出:
IOException - 如果发生 I/O 错误
从以下版本开始:
1.5

flush

public abstract void flush()
                    throws IOException
刷新此流。如果此流已保存缓冲区中各种 write() 方法的任何字符,则立即将它们写入预期目标。然后,如果该目标是另一个字符或字节流,则将其刷新。因此,一次 flush() 调用将刷新 Writer 和 OutputStream 链中的所有缓冲区。

如果此流的预期目标是由基础操作系统提供的一个抽象(如一个文件),则刷新此流只能保证将以前写入到流的字节传递给操作系统进行写入,但不保证能将这些字节实际写入到物理设备(如磁盘驱动器)。

指定者:
接口 Flushable 中的 flush
抛出:
IOException - 如果发生 I/O 错误

close

public abstract void close()
                    throws IOException
关闭此流,但要先刷新它。在关闭流之后,再调用 write() 或 flush() 将导致抛出 IOException。然而,关闭以前关闭的流无效。
指定者:
接口 Closeable 中的 close
抛出:
IOException - 如果发生 I/O 错误

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文