我正在尝试解析一个相当大的 XML 文件 - 1MB+,但我遇到了一些困难。
我首先尝试将 xml 文件添加到 res/xml 并使用 XmlResourceParser 解析它,但出现异常“数据超出 UNCOMPRESS_DATA_MAX”。经过一番研究后,我发现压缩文件在读取之前必须在内存中解压缩,并且此限制不适用于原始文件。
然而,当尝试使用 SAXParser 解析 res/raw 文件夹中的 xml 文件时,我收到 IOException,没有任何消息和堆栈跟踪:
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser sp = spf.newSAXParser();
XMLReader xr = sp.getXMLReader();
xr.setContentHandler(myXMLHandler);
InputSource src = new InputSource(stream);
xr.parse(src); // IOException
据我了解,这些内存限制不适用于原始资源,但是是什么导致了这个异常呢?
这是来自 logcat 的堆栈跟踪:
11-11 23:47:50.729: WARN/System.err(4886): java.io.IOException
11-11 23:47:50.739: WARN/System.err(4886): at android.content.res.AssetManager.readAsset(Native Method)
11-11 23:47:50.749: WARN/System.err(4886): at android.content.res.AssetManager.access$800(AssetManager.java:36)
11-11 23:47:50.759: WARN/System.err(4886): at android.content.res.AssetManager$AssetInputStream.read(AssetManager.java:542)
11-11 23:47:50.759: WARN/System.err(4886): at org.apache.harmony.xml.ExpatParser.parseFragment(ExpatParser.java:504)
11-11 23:47:50.769: WARN/System.err(4886): at org.apache.harmony.xml.ExpatParser.parseDocument(ExpatParser.java:467)
11-11 23:47:50.779: WARN/System.err(4886): at org.apache.harmony.xml.ExpatReader.parse(ExpatReader.java:329)
11-11 23:47:50.790: WARN/System.err(4886): at org.apache.harmony.xml.ExpatReader.parse(ExpatReader.java:286)
使用这个 linux 命令分割你的文件split -l 1 main.xml
private String readTxt()
{
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
for(int J=1;J<15;J++)
{
int i;
try
{
InputStream raw = this.getAssets().open("xa"+J);
i = raw.read();
while (i != -1)
{
byteArrayOutputStream.write(i);
i = raw.read();
}
raw.close();
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
}
用作 SAX 解析中的字符串。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)