public class XMLEncoder extends Encoder implements AutoCloseable
XMLEncoderクラスは、ObjectOutputStreamの補足的な代替であり、ObjectOutputStreamを使ってSerializableオブジェクトのバイナリ表現を作成できるのと同じ方法でJavaBeanのテキスト表現を生成するために使用できます。 たとえば、次のコードでは、提供されたJavaBeanとそのすべてのプロパティのテキスト表現を生成できます。
XMLEncoder e = new XMLEncoder(
new BufferedOutputStream(
new FileOutputStream("Test.xml")));
e.writeObject(new JButton("Hello, world"));
e.close();
APIは似ているものの、XMLEncoderクラスは、JavaBeanのグラフをその公開プロパティのテキスト表現としてアーカイブ化する目的で設計されています。 この方式で作成された文書は、Javaソース・ファイルと同様、必要なクラスの実装が変更から保護されています。 プロセス間通信および通常目的の直列化には、これまでどおりObjectOutputStreamを使用することをお薦めします。
XMLEncoderクラスは、JavaBeanを、XML仕様バージョン1.0とUnicode/ISO 10646文字セットのUTF-8文字エンコーディングに準拠したXML文書として表現するデフォルトの指定を提供します。 XMLEncoderクラスによって生成されるXML文書には、次のような特徴があります。
XMLEncoderクラスは内部で冗長性削減アルゴリズムを使用するため、Beanのプロパティのデフォルト値がストリームに書き込まれません。
次に、swingツールキットのユーザー・インタフェース・コンポーネントを含むXMLアーカイブの例を示します。
<?xml version="1.0" encoding="UTF-8"?>
<java version="1.0" class="java.beans.XMLDecoder">
<object class="javax.swing.JFrame">
<void property="name">
<string>frame1</string>
</void>
<void property="bounds">
<object class="java.awt.Rectangle">
<int>0</int>
<int>0</int>
<int>200</int>
<int>200</int>
</object>
</void>
<void property="contentPane">
<void method="add">
<object class="javax.swing.JButton">
<void property="label">
<string>Hello</string>
</void>
</object>
</void>
</void>
<void property="visible">
<boolean>true</boolean>
</void>
</object>
</java>
XML構文は、次の規約に準拠しています。
すべてのオブジェクト・グラフはこれら3つのタグで記述できますが、共通のデータ構造をより簡潔に表現するため、次の定義がなされています。
Integerクラスのインスタンスは<int>123</int>と記述できる。 XMLEncoderクラスが、Javaプリミティブ型と関連ラッパー・クラス間の変換を内部的に処理するJavaリフレクション・パッケージを使用する点に注意すること。 XMLEncoderクラスのAPI自体は、Objectだけを取り扱う。
詳細は、「The Swing Connection」の「Using XMLEncoder」を参照してください。
XMLDecoder, ObjectOutputStream| コンストラクタ | 説明 |
|---|---|
XMLEncoder(OutputStream out) |
XMLエンコーディングを使用してJavaBeansをストリーム
outに書き出すための新しいXMLエンコーダを作成します。 |
XMLEncoder(OutputStream out, String charset, boolean declaration, int indentation) |
指定された
charsetを使用し、指定されたindentationから開始してJavaBeansをストリームoutに書き出すための新しいXMLエンコーダを作成します。 |
| 修飾子と型 | メソッド | 説明 |
|---|---|---|
void |
close() |
このメソッドは、
flushを呼び出し、閉じるポストアンブルを書き込んでから、このストリームに関連付けられている出力ストリームを閉じます。 |
void |
flush() |
このメソッドは、XMLエンコーディングに関連付けられているプリアンブルを書き出し(まだ書き出されていない場合)、
flushを最後に呼び出したときからストリームに書き込まれたすべての値を書き出します。 |
Object |
getOwner() |
このエンコーダの所有者を取得します。
|
void |
setOwner(Object owner) |
このエンコーダの所有者を
ownerに設定します。 |
void |
writeExpression(Expression oldExp) |
ストリームのフラッシュ時に実際の出力が生成されるように、式を記録します。
|
void |
writeObject(Object o) |
指定されたオブジェクトのXML表現を出力に書き込みます。
|
void |
writeStatement(Statement oldStm) |
ストリームのフラッシュ時に実際の出力が生成されるように、文を記録します。
|
get, getExceptionListener, getPersistenceDelegate, remove, setExceptionListener, setPersistenceDelegatepublic XMLEncoder(OutputStream out)
outに書き出すための新しいXMLエンコーダを作成します。out - オブジェクトのXML表現の書込み先となるストリームIllegalArgumentException - outがnullである場合XMLDecoder.XMLDecoder(InputStream)public XMLEncoder(OutputStream out, String charset, boolean declaration, int indentation)
charsetを使用し、指定されたindentationから開始してJavaBeansをストリームoutに書き出すための新しいXMLエンコーダを作成します。out - オブジェクトのXML表現の書込み先となるストリームcharset - 要求された文字セットの名前。正規名か別名declaration - XML宣言を生成するかどうか。別のXMLドキュメントのコンテンツを埋め込む場合は、falseに設定しますindentation - XMLドキュメント全体をインデントするための空白文字の数IllegalArgumentException - outまたはcharsetがnullの場合、あるいはindentationが0より小さい場合IllegalCharsetNameException - charsetの名前が不正な場合UnsupportedCharsetException - 指定された文字セットが現在のJava仮想マシンでは利用できない場合UnsupportedOperationException - ロードされた文字セットがエンコーディングをサポートしない場合Charset.forName(String)public void setOwner(Object owner)
ownerに設定します。owner - このエンコーダの所有者。getOwner()public Object getOwner()
setOwner(java.lang.Object)public void writeObject(Object o)
writeObject、クラスEncodero - ストリームに書き込まれるオブジェクト。XMLDecoder.readObject()public void writeStatement(Statement oldStm)
このメソッドは、持続的な委譲を初期化するコンテキスト内だけで呼び出すようにしてください。
writeStatement、クラスEncoderoldStm - ストリームに書き込まれる文。PersistenceDelegate.initialize(java.lang.Class<?>, java.lang.Object, java.lang.Object, java.beans.Encoder)public void writeExpression(Expression oldExp)
このメソッドは、持続的な委譲を初期化するコンテキスト内、またはリソース・バンドルから読み込むようにエンコーダを設定するコンテキスト内だけで呼び出すようにしてください。
XMLEncoderでリソース・バンドルを使用する詳細については、http://java.sun.com/products/jfc/tsc/articles/persistence4/#i18nを参照してください。
writeExpression、クラスEncoderoldExp - ストリームに書き込まれる式。PersistenceDelegate.initialize(java.lang.Class<?>, java.lang.Object, java.lang.Object, java.beans.Encoder)public void flush()
flushを最後に呼び出したときからストリームに書き込まれたすべての値を書き出します。 フラッシュ後、このストリームに書き込まれた値の内部参照はすべてクリアされます。 public void close()
flushを呼び出し、閉じるポストアンブルを書き込んでから、このストリームに関連付けられている出力ストリームを閉じます。close、インタフェースAutoCloseable バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。 そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2025, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Documentation Redistribution Policyも参照してください。