关于UI线程与子线程的通讯方式
View.post 可读性差,维护困难,一来View对象
AsyncTask
handler.post 强大,用的多
RunOnUIThread
都可以实现主进程更新UI
对主进程UI界面控件进行修改的模型图,如图:
关于 applicationContext 和 context
官网的说法是:
1,如果你觉得这个对象用完就扔,那么使用context,反之活的久一点
2,如果你很多地方使用applicationContext 并且还忘记unregister,unbind,etc 那么就很容易造成泄露,等严重错误;
关于notifycation
收到的时候不会打断当前应用程序,,会现在状态栏提示一下,是一种延迟消息
关于bundle
bundle是一个类似与map的对象,只不过他的key是String
关于xml文件处理
javaee平台有两种方式 sax dom
android 集成了pull解析器(android平台的xml很多,足以见得该方法的优越性)
xml文件如:(有属性的叫Emelment Node 无属性的Node叫Text Node)
<?xml version="1.0" encoding="utf-8"?>
<manifest>
<application id="application1">
<activity1>
11
</activity1>
<activity2>
12
</activity2>
</application>
<application id="application2">
<activity1>
21
</activity1>
<activity2>
22
</activity2>
</application>
</manifest>
解析部分示例伪代码:
XmlPullParser xmlPullParser = Xml.newPullParser();
xmlPullParser.setInput("文件流","文件编码:UTF-8");
int event = xmlPullParser.getEventType();//这里保存这个事件类型供while判断是否结束
while (event != XmlPullParser.END_DOCUMENT){
switch (event){
case XmlPullParser.START_DOCUMENT:
//文档解析开始的操作,一般是序列化,初始化
break;
case XmlPullParser.START_TAG:
//每一个节点
xmlPullParser.getName() 获取节点名字 activity1
xmlPullParser.getNextText()获取activity1这个节点的值,并移动到下一个节点
break;
}
event = xmlPullParser.next();//递归找到下一个节点(这里需要跑一个异常Exception)
}
生成部分示例伪代码:
XmlSerializer serializer = Xml.newSerializer();
serializer.setOutput("输出流","UTF-8");
serializer.startDocument("UTF-8",true);//第二个参数代表是否有其他关联xml,这里要跑一个异常
serializer.startTag(null,"manifest");//开始加入标签,第一个参数代表命名空间
for(){//for循环加数据
serializer.startTag(null,"application");
serializer.attribute(null,"id","application1");
serializer.startTag(null,"activity1");
serializer.text("11");
serializer.endTag(null,"activity1");
serializer.startTag(null,"activity2");
serializer.text("12");
serializer.endTag(null,"activity2");
serializer.endTag(null,"application");
}
serializer.endTag(null,"manifest");//对应前面的标签结束标志
serializer.endDocument();//对应前面的文档结束标志
}
持续更新中….