用pull解析xml时,xml文件放在哪

用pull解析xml时,xml文件放在哪,第1张

Pull解析方法给应用程序完全的控制文档该怎么样被解析。Android中对Pull方法提供了支持的API,主要是

复制代码代码如下:

orgxmlpullv1XmlPullParser;

orgxmlpullv1XmlPullParserFactory;

二个类,其中主要使用的是XmlPullParser,XmlPullParserFactory是一个工厂,用于构建XmlPullParser对象。

应用程序通过调用XmlPullParsernext()等方法来产生Event,然后再处理Event。可以看到它与Push方法的不同,Push方法是由Parser自己主动产生Event,回调给应用程序。而Pull方法是主动的调用Parser的方法才能产生事件

假如XML中的语句是这样的:"<author country="United States">James Elliott</author>",author是TAG,country是ATTRIBUTE,"James Elliott"是TEXT。

要想解析文档先要构建一个XmlPullParser对象

复制代码代码如下:

final XmlPullParserFactory factory = XmlPullParserFactorynewInstance();

factorysetNamespaceAware(true);

final XmlPullParser parser = factorynewPullParser();

Pull解析是一个遍历文档的过程,每次调用next(),nextTag(), nextToken()和nextText()都会向前推进文档,并使Parser停留在某些事件上面,但是不能倒退。

然后把文档设置给Parser

复制代码代码如下:

parsersetInput(new StringReader("<author country=\"United States\">James Elliott</author>");

这时,文档刚被初始化,所以它应该位于文档的开始,事件应该是START_DOCUMENT,可以通过XmlPullParsergetEventType()来获取。然后调用next()会产生

START_TAG,这个事件告诉应用程序一个标签已经开始了,调用getName()会返回"author";再next()会产生

TEXT事件,调用getText()会返回"James Elliott",再next(),会产生

END_TAG,这个告诉你一个标签已经处理完了,再next(),会产生

END_DOCUMENT,它告诉你整个文档已经处理完成了。

除了next()外,nextToken()也可以使用,只不过它会返回更加详细的事件,比如 COMMENT, CDSECT, DOCDECL, ENTITY等等非常详细的信息。如果程序得到比较底层的信息,可以用nextToken()来驱动并处理详细的事件。需要注意一点的是TEXT事件是有可能返回空白的White Spaces比如换行符或空格等。

另外有二个非常实用的方法nextTag()和nextText()

nextTag()--首先它会忽略White Spaces,如果可以确定下一个是START_TAG或END_TAG,就可以调用nextTag()直接跳过去。通常它有二个用处:当START_TAG时,如果能确定这个TAG含有子TAG,那么就可以调用nextTag()产生子标签的START_TAG事件;当END_TAG时,如果确定不是文档结尾,就可以调用nextTag()产生下一个标签的START_TAG。在这二种情况下如果用next()会有TEXT事件,但返回的是换行符或空白符。

nextText()--它只能在START_TAG时调用。当下一个元素是TEXT时,TEXT的内容会返回;当下一个元素是END_TAG时,也就是说这个标签的内容为空,那么空字串返回;这个方法返回后,Parser会停在END_TAG上。比如:

复制代码代码如下:

<author>James Elliott</author>

<author></author>

<author/>

当START_TAG时,调用nextText(),依次返回:

"James Elliott"

""(empty)

""(empty)

这个方法在处理没有子标签的标签时很有用。比如:

复制代码代码如下:

<title>What Is Hibernate</title>

<author>James Elliott</author>

<category>Web</category>

就可以用以下代码来处理:

复制代码代码如下:

while (eventType != XmlPullParserEND_TAG) {

switch (eventType) {

case XmlPullParserSTART_TAG:

tag = parsergetName();

final String content = parsernextText();

Loge(TAG, tag + ": [" + content + "]");

eventType = parsernextTag();

break;

default:

break;

}

}

那是因为你没有你没把那个JAR包导出

在项目属性->Java Build Path -> Order and Export里的kxml的包勾起来,这样就不会提示类找不到了。

日常开发中,LayoutInflater的inflate()是我们经常使用的一个方法,同时也是面试中经常考察的一个知识点,它的作用是把一个xml布局填充成对应的View对象。

在LayoutInflater类中,有如下几个重载的inflate()方法:

日常开发中,使用最多的应该是前两个,它们的调用关系(箭头指向表示调用方向)如下:

从图中可以看出前三个最终调用的都是最后一个方法,因此我们只需集中精力搞清楚最后一个方法就可以了,它的源码如下:

其中第一个参数 XmlPullParser parser 是由xml转换而来的pull解析器,用来对xml布局进行解析。

对于第二个参数 @Nullable ViewGroup root ,当attachToRoot为true时,root就是xml所填充成的view对象的父view;当attachToRoot为false的时候,root仅用来帮助决定xml根节点的LayoutParams,这块不理解的话,可以看下view的绘制流程,子view的大小是由父view的measureSpec和子view的宽高值决定的。

而第三个参数 boolean attachToRoot ,就如上面所说,用来决定xml布局和root是否存在父子布局关系。

结合上面的源码分析,可以得出如下结论

此外,stackoverflow上的 这个回答 也精准阐述了本篇文章所探讨的内容,感兴趣的可以看一下。

以上就是关于用pull解析xml时,xml文件放在哪全部的内容,包括:用pull解析xml时,xml文件放在哪、J2me开发错误:java.lang.ClassNotFoundException、LayoutInflater.inflate()详解等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9830303.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存