首先,咱们看一下什么是serializer,serializer就是串行化,又名序列化。它可并不仅是简单的把对象保存在存储器上,它可使咱们在流中传输对象,使对象变的能够像基本数据同样传递。html
最终效果图如上java
如今粘贴主要代码:android
main.xml
api
[xhtml] view plaincopyapp
<?xml version="1.0" encoding="utf-8"?> ide
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 测试
android:orientation="vertical" this
android:layout_width="fill_parent" 编码
android:layout_height="fill_parent" spa
>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/textView"
/>
</LinearLayout>
activity的代码
[java] view plaincopy
package cn.com.xmlseriliazer;
import java.io.StringWriter;
import java.util.ArrayList;
import org.xmlpull.v1.XmlPullParserFactory;
import org.xmlpull.v1.XmlSerializer;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
/**
*
* @author chenzheng_java
* @description 测试经过XmlSerilizer生成xml文件
*
*
*/
public class XmlSerializerActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
String result = produceXml();
TextView textView = (TextView)this.findViewById(R.id.textView);
textView.setText(result);
}
/**
*
* @return 生成的xml文件的字符串表示
*/
private String produceXml(){
StringWriter stringWriter = new StringWriter();
ArrayList<Beauty> beautyList = getData();
try {
// 获取XmlSerializer对象
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlSerializer xmlSerializer = factory.newSerializer();
// 设置输出流对象
xmlSerializer.setOutput(stringWriter);
/*
* startDocument(String encoding, Boolean standalone)encoding表明编码方式
* standalone 用来表示该文件是否呼叫其它外部的文件。
* 若值是 ”yes” 表示没有呼叫外部规则文件,若值是 ”no” 则表示有呼叫外部规则文件。默认值是 “yes”。
*/
xmlSerializer.startDocument("utf-8", true);
xmlSerializer.startTag(null, "beauties");
for(Beauty beauty:beautyList){
/*
* startTag (String namespace, String name)这里的namespace用于惟一标识xml标签
*XML 命名空间属性被放置于某个元素的开始标签之中,并使用如下的语法:
xmlns:namespace-prefix="namespaceURI"
当一个命名空间被定义在某个元素的开始标签中时,全部带有相同前缀的子元素都会与同一个命名空间相关联。
注释:用于标示命名空间的地址不会被解析器用于查找信息。其唯一的做用是赋予命名空间一个唯一的名称。不过,不少公司经常会做为指针来使用命名空间指向某个实存的网页,这个网页包含着有关命名空间的信息。
*/
xmlSerializer.startTag(null, "beauty");
xmlSerializer.startTag(null, "name");
xmlSerializer.text(beauty.getName());
xmlSerializer.endTag(null, "name");
xmlSerializer.startTag(null, "age");
xmlSerializer.text(beauty.getAge());
xmlSerializer.endTag(null, "age");
xmlSerializer.endTag(null, "beauty");
}
xmlSerializer.endTag(null, "beauties");
xmlSerializer.endDocument();
} catch (Exception e) {
e.printStackTrace();
}
return stringWriter.toString();
}
/**
*
* @return 包含了众多美女信息的集合
*/
private ArrayList<Beauty> getData(){
ArrayList<Beauty> beautyList = new ArrayList<Beauty>();
Beauty yangmi = new Beauty("杨幂", "23");
Beauty linzhiling = new Beauty("林志玲", "28");
beautyList.add(yangmi);
beautyList.add(linzhiling);
return beautyList;
}
/**
*
* @author chenzheng_java
* 美人实体类
*/
private class Beauty{
String name;
String age ;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
@Override
public String toString() {
return "Beauty [age=" + age + ", name=" + name + "]";
}
public Beauty(String name, String age) {
this.name = name;
this.age = age;
}
public Beauty(){
}
}
}
其余都为默认。
由代码咱们能够看到,其实使用xmlserializer生成xml也是至关容易的。基本的步骤和解析xml差很少。这里就很少说话了。详情请看api。