|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object java.io.Writer java.io.OutputStreamWriter
public class OutputStreamWriter
OutputStreamWriter は、文字ストリームからバイトストリームへの橋渡しの役目を持ちます。バイトストリームに書き込まれた文字は、指定された
を使用してバイトに符号化されます。使用される文字セットは、名前で指定することも、明示的に渡すことも、またはプラットフォームのデフォルトの文字セットをそのまま使うこともできます。
charset
write() メソッドを呼び出すたびに、指定された文字に対してエンコーディングコンバータが呼び出されます。結果として得られるバイトは、バッファーに蓄積されてから基本となる出力ストリームに書き込まれます。このバッファーのサイズは指定できますが、ほとんどの場合、デフォルトのサイズで十分です。write() メソッドに渡される文字はバッファーに入らないので注意してください。
最大限に効率化するには、コンバータを頻繁に呼び出さないようにするために BufferedWriter の内部に OutputStreamWriter をラップすることを考慮してください。例を示します。
Writer out = new BufferedWriter(new OutputStreamWriter(System.out));
「サロゲートペア」は、2 つの char 値によって表される文字です。\uD800 〜 \uDBFF の「上位」サロゲートと、それに続く \uDC00 〜 \uDFFF の「下位」サロゲートで構成されます。
対応する下位サロゲートがない上位サロゲート、または対応する上位サロゲートがない下位サロゲートは、「不正なサロゲート要素」と呼ばれます。
このクラスは、不正なサロゲート要素やマップ不可文字シーケンスを、常に文字セットのデフォルトの「代替シーケンス」で置き換えます。符号化処理をより強力に制御する必要がある場合は、CharsetEncoder クラスを使用してください。
BufferedWriter
,
OutputStream
,
Charset
フィールドの概要 |
---|
クラス java.io.Writer から継承されたフィールド |
---|
lock |
コンストラクタの概要 | |
---|---|
OutputStreamWriter(OutputStream out)
デフォルトの文字セットを使う OutputStreamWriter を作成します。 |
|
OutputStreamWriter(OutputStream out,
Charset cs)
与えられた文字セットを使う OutputStreamWriter を作成します。 |
|
OutputStreamWriter(OutputStream out,
CharsetEncoder enc)
与えられた文字セットエンコーダを使う OutputStreamWriter を作成します。 |
|
OutputStreamWriter(OutputStream out,
String charsetName)
指定された文字セットを使う OutputStreamWriter を作成します。 |
メソッドの概要 | |
---|---|
void |
close()
ストリームを最初にフラッシュして、閉じます。 |
void |
flush()
ストリームをフラッシュします。 |
String |
getEncoding()
このストリームで使用される文字エンコーディングの名前を返します。 |
void |
write(char[] cbuf,
int off,
int len)
文字の配列の一部を書き込みます。 |
void |
write(int c)
単一の文字を書き込みます。 |
void |
write(String str,
int off,
int len)
文字列の一部を書き込みます。 |
クラス java.io.Writer から継承されたメソッド |
---|
append, append, append, write, write |
クラス java.lang.Object から継承されたメソッド |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
コンストラクタの詳細 |
---|
public OutputStreamWriter(OutputStream out, String charsetName) throws UnsupportedEncodingException
out
- OutputStreamcharsetName
- サポートする charset
の名前
UnsupportedEncodingException
- 指定された文字エンコーディングがサポートされていない場合public OutputStreamWriter(OutputStream out)
out
- OutputStreampublic OutputStreamWriter(OutputStream out, Charset cs)
out
- OutputStreamcs
- charsetpublic OutputStreamWriter(OutputStream out, CharsetEncoder enc)
out
- OutputStreamenc
- 文字セットエンコーダメソッドの詳細 |
---|
public String getEncoding()
エンコーディングに互換名がある場合は、その名前を返します。互換名がない場合は、エンコーディングの正規名を返します。
このインスタンスが OutputStreamWriter(OutputStream, String)
コンストラクタを使用して作成された場合は、エンコーディングに対して一意となる名前が返され、コンストラクタに渡された名前とは異なることがあります。ストリームが閉じられた場合、このメソッドは null を返すことがあります。
null
Charset
public void write(int c) throws IOException
Writer
内の write
c
- 書き込む文字を指定する int
IOException
- 入出力エラーが発生した場合public void write(char[] cbuf, int off, int len) throws IOException
Writer
内の write
cbuf
- 文字のバッファーoff
- 文字の書き込み開始オフセットlen
- 書き込む文字数
IOException
- 入出力エラーが発生した場合public void write(String str, int off, int len) throws IOException
Writer
内の write
str
- 文字列off
- 文字の書き込み開始オフセットlen
- 書き込む文字数
IOException
- 入出力エラーが発生した場合public void flush() throws IOException
Flushable
内の flush
Writer
内の flush
IOException
- 入出力エラーが発生した場合public void close() throws IOException
Writer
の記述:
Closeable
内の close
Writer
内の close
IOException
- 入出力エラーが発生した場合
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。