一、關于Junit測試
首先需要在manifest.xml中配置,在manifest節(jié)點下指定以下信息其中targetPacketage是你想要測試的項目的包名
<!-- 指定測試信息和要測試的包 -->
<instrumentation
android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.itheima28.junittest" >
</instrumentation>
在application節(jié)點下加入
<!-- 指定引用的測試包 -->
<uses-library android:name="android.test.runner" />
使用時直接繼承AndroidTestCase即可
public class TestCase extends AndroidTestCase {
public void test() {
。。。。
}
}
二、使用XmlSerializer類序列化XML
XmlSerializer主要是以數(shù)據(jù)流的形式序列化XML而它是一個接口無法直接實例化,需要通過一個靜態(tài)方法Xml.newSerializer獲取對象
下面是一些常用的方法
startDocument(String,boolean):第一個參數(shù)設置文檔的編碼格式,第二個參數(shù)設置是否是一個獨立的文檔,一般設置為true。
endDocument():標記XML文檔的結束,XML文檔標簽均為成對出現(xiàn),有始有終。
startTag(String,String):一個XML標簽的開始,第一個參數(shù)為命名空間,一般為null即可,第二個參數(shù)為標簽名。
endTag(String,String):一個XML標簽的結束,第一個參數(shù)為命名空間,一般為null即可,第二個參數(shù)為標簽名,有始有終。
attribute(String,String,String):設置一個標簽的屬性,第一個參數(shù)為命名空間,第二個參數(shù)是屬性名,第三個參數(shù)為屬性值。
text(String/...):設置標簽的值
下面是一個實例
public class TestCase extends AndroidTestCase {
public void test() {
// writeXmlToLocal();
List<Person> personList = parserXmlFromLocal();
for (Person person : personList) {
Log.i("TestCase", person.toString());
}
}
/**
* 寫xml文件到本地
*/
private void writeXmlToLocal() {
List<Person> personList = getPersonList();
// 獲得序列化對象
XmlSerializer serializer = Xml.newSerializer();
try {
File path = new File(Environment.getExternalStorageDirectory(), "persons.xml");
FileOutputStream fos = new FileOutputStream(path);
// 指定序列化對象輸出的位置和編碼
serializer.setOutput(fos, "utf-8");
serializer.startDocument("utf-8", true); // 寫開始 <?xml version='1.0' encoding='utf-8' standalone='yes' ?>
serializer.startTag(null, "persons"); // <persons>
for (Person person : personList) {
// 開始寫人
serializer.startTag(null, "person"); // <person>
serializer.attribute(null, "id", String.valueOf(person.getId()));
// 寫名字
serializer.startTag(null, "name"); // <name>
serializer.text(person.getName());
serializer.endTag(null, "name"); // </name>
// 寫年齡
serializer.startTag(null, "age"); // <age>
serializer.text(String.valueOf(person.getAge()));
serializer.endTag(null, "age"); // </age>
serializer.endTag(null, "person"); // </person>
}
serializer.endTag(null, "persons"); // </persons>
serializer.endDocument(); // 結束
} catch (Exception e) {
e.printStackTrace();
}
}
private List<Person> getPersonList() {
List<Person> personList = new ArrayList<Person>();
for (int i = 0; i < 30; i++) {
personList.add(new Person(i, "wang" + i, 18 + i));
}
return personList;
}
}
三、使用pull解析XML
PULL解析器的運行方式和SAX解析器很相似,都是事件觸發(fā)機制。如開始元素和結束元素,使用parser.next()可以進行下一個元素并觸發(fā)相應的事件,事件作為代碼被發(fā)送,返回值是數(shù)字,因此可以用一個switch語句來對事件進行選擇,然后進行相應的處理,當開始解析元素的時候,調(diào)用parser.nextText()方法可以獲得下一個Text類型的元素。
常用屬性
START_DOCUMENT
START_TAG
TEXT
END_TAG
END_DOCUMENT
private List<Person> parserXmlFromLocal() {
try {
File path = new File(Environment.getExternalStorageDirectory(), "persons.xml");
FileInputStream fis = new FileInputStream(path);
// 獲得pull解析器對象
XmlPullParser parser = Xml.newPullParser();
// 指定解析的文件和編碼格式
parser.setInput(fis, "utf-8");
int eventType = parser.getEventType(); // 獲得事件類型
List<Person> personList = null;
Person person = null;
String id;
while(eventType != XmlPullParser.END_DOCUMENT) {
String tagName = parser.getName(); // 獲得當前節(jié)點的名稱
switch (eventType) {
case XmlPullParser.START_TAG: // 當前等于開始節(jié)點 <person>
if("persons".equals(tagName)) { // <persons>
personList = new ArrayList<Person>();
} else if("person".equals(tagName)) { // <person id="1">
person = new Person();
id = parser.getAttributeValue(null, "id");
person.setId(Integer.valueOf(id));
} else if("name".equals(tagName)) { // <name>
person.setName(parser.nextText());
} else if("age".equals(tagName)) { // <age>
person.setAge(Integer.parseInt(parser.nextText()));
}
break;
case XmlPullParser.END_TAG: // </persons>
if("person".equals(tagName)) {
// 需要把上面設置好值的person對象添加到集合中
personList.add(person);
}
break;
default:
break;
}
eventType = parser.next(); // 獲得下一個事件類型
}
return personList;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}