Android XML解析java.lang.OutOfMemoryError:[内存耗尽]

Android XML解析java.lang.OutOfMemoryError:[内存耗尽],android,android-layout,Android,Android Layout,您好,我正在用下面的代码解析xml @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); InputStream is = getResources().openRawResource(R.raw.bd); try {

您好,我正在用下面的代码解析xml

       @Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    InputStream is = getResources().openRawResource(R.raw.bd);
    try {
        DocumentBuilder docBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
        Document doc = docBuilder.parse(is, null);
        doc.getDocumentElement().normalize();
        NodeList my_words = doc.getElementsByTagName("word");
        for (int i = 0; i < 100; i++) {
            System.out.println(((Element) my_words.item(i)).getAttribute("eng"));
            System.out.println(((Element) my_words.item(i)).getAttribute("guj"));
        }
        is.close();

    } catch (Exception e) {
        e.printStackTrace();
    }
}
@覆盖
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
InputStream is=getResources().openRawResource(R.raw.bd);
试一试{
DocumentBuilder docBuilder=DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc=docBuilder.parse(为空);
doc.getDocumentElement().normalize();
NodeList my_words=doc.getElementsByTagName(“word”);
对于(int i=0;i<100;i++){
System.out.println(((Element)my_words.item(i)).getAttribute(“eng”);
System.out.println(((Element)my_words.item(i)).getAttribute(“guj”);
}
is.close();
}捕获(例外e){
e、 printStackTrace();
}
}
但我得到的错误如下

          01-11 16:00:48.709: E/dalvikvm-heap(18535): Out of memory on a 176-byte allocation.
          01-11 16:00:48.709: I/dalvikvm(18535): "main" prio=5 tid=1 RUNNABLE
          01-11 16:00:48.709: I/dalvikvm(18535):   | group="main" sCount=0 dsCount=0 obj=0x40022190 self=0xd018
          01-11 16:00:48.709: I/dalvikvm(18535):   | sysTid=18535 nice=0 sched=0/0 cgrp=[fopen-error:2] handle=-1345002400
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.Throwable.nativeFillInStackTrace(Native Method)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.Throwable.fillInStackTrace(Throwable.java:135)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.Throwable.<init>(Throwable.java:74)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.Error.<init>(Error.java:38)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.VirtualMachineError.<init>(VirtualMachineError.java:36)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.OutOfMemoryError.<init>(OutOfMemoryError.java:34)
          01-11 16:00:48.709: I/dalvikvm(18535):   at java.util.ArrayList.add(ArrayList.java:-1)
          01-11 16:00:48.709: I/dalvikvm(18535):   at org.apache.harmony.xml.dom.ElementImpl.setAttributeNode(ElementImpl.java:329)
          01-11 16:00:48.709: I/dalvikvm(18535):   at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:355)
          01-11 16:00:48.709: I/dalvikvm(18535):   at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:360)
          01-11 16:00:48.709: I/dalvikvm(18535):   at org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:133)
          01-11 16:00:48.709: I/dalvikvm(18535):   at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:132)
          01-11 16:00:48.709: I/dalvikvm(18535):   at com.example.simplexmlpullapp.MainActivity.onCreate(MainActivity.java:32)
          01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
          01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1722)
          01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1784)
          01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.ActivityThread.access$1500(ActivityThread.java:123)
         01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:939)
         01-11 16:00:48.709: I/dalvikvm(18535):   at android.os.Handler.dispatchMessage(Handler.java:99)
         01-11 16:00:48.709: I/dalvikvm(18535):   at android.os.Looper.loop(Looper.java:130)
         01-11 16:00:48.709: I/dalvikvm(18535):   at android.app.ActivityThread.main(ActivityThread.java:3835)
         01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.reflect.Method.invokeNative(Native Method)
         01-11 16:00:48.709: I/dalvikvm(18535):   at java.lang.reflect.Method.invoke(Method.java:507)
         01-11 16:00:48.709: I/dalvikvm(18535):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
         01-11 16:00:48.709: I/dalvikvm(18535):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
         01-11 16:00:48.709: I/dalvikvm(18535):   at dalvik.system.NativeStart.main(Native Method)
         01-11 16:00:48.729: W/dalvikvm(18535): Exception thrown (Ljava/lang/OutOfMemoryError;) while throwing internal exception (Ljava/lang/OutOfMemoryError;)
        01-11 16:00:48.729: W/dalvikvm(18535): Could not resolve class ref'ed in exception catch list (class index 349, exception Ljava/lang/OutOfMemoryError;)
        01-11 16:00:49.209: I/dalvikvm-heap(18535): Clamp target GC heap from 25.906MB to 24.000MB
        01-11 16:00:49.209: D/dalvikvm(18535): GC_CONCURRENT freed <1K, 11% free 22006K/24519K, external 3K/514K, paused 5ms+6ms
        01-11 16:00:49.509: D/dalvikvm(18535): GC_FOR_MALLOC freed 19308K, 89% free 2698K/24519K, external 3K/514K, paused 294ms
        01-11 16:00:49.509: D/AndroidRuntime(18535): Shutting down VM
        01-11 16:00:49.509: W/dalvikvm(18535): threadid=1: thread exiting with uncaught exception (group=0x40018560)
        01-11 16:00:49.509: E/AndroidRuntime(18535): FATAL EXCEPTION: main
        01-11 16:00:49.509: E/AndroidRuntime(18535): java.lang.OutOfMemoryError: [memory exhausted]
        01-11 16:00:49.509: E/AndroidRuntime(18535):    at dalvik.system.NativeStart.main(Native Method)
01-11 16:00:48.709:E/dalvikvm堆(18535):176字节分配的内存不足。
01-11 16:00:48.709:I/dalvikvm(18535):“主”优先级=5 tid=1可运行
01-11 16:00:48.709:I/dalvikvm(18535):| group=“main”scont=0 dsCount=0 obj=0x40022190 self=0xd018
01-11 16:00:48.709:I/dalvikvm(18535):| sysTid=18535 nice=0 sched=0/0 cgrp=[fopen错误:2]句柄=-1345002400
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.Throwable.nativeFillInStackTrace(本机方法)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.Throwable.fillInStackTrace(Throwable.java:135)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.Throwable.(Throwable.java:74)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.Error.(Error.java:38)
01-11 16:00:48.709:I/dalvikvm(18535):在java.lang.VirtualMachineError(VirtualMachineError.java:36)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.OutOfMemoryError。(OutOfMemoryError.java:34)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.util.ArrayList.add(ArrayList.java:-1)
01-11 16:00:48.709:I/dalvikvm(18535):位于org.apache.harmony.xml.dom.ElementImpl.setAttributeNode(ElementImpl.java:329)
01-11 16:00:48.709:I/dalvikvm(18535):位于org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:355)
01-11 16:00:48.709:I/dalvikvm(18535):位于org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:360)
01-11 16:00:48.709:I/dalvikvm(18535):位于org.apache.harmony.xml.parsers.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:133)
01-11 16:00:48.709:I/dalvikvm(18535):位于javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:132)
01-11 16:00:48.709:I/dalvikvm(18535):位于com.example.simplexmlpullapp.MainActivity.onCreate(MainActivity.java:32)
01-11 16:00:48.709:I/dalvikvm(18535):位于android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-11 16:00:48.709:I/dalvikvm(18535):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1722)
01-11 16:00:48.709:I/dalvikvm(18535):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1784)
01-11 16:00:48.709:I/dalvikvm(18535):在android.app.ActivityThread.access$1500(ActivityThread.java:123)
01-11 16:00:48.709:I/dalvikvm(18535):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:939)
01-11 16:00:48.709:I/dalvikvm(18535):在android.os.Handler.dispatchMessage(Handler.java:99)上
01-11 16:00:48.709:I/dalvikvm(18535):位于android.os.Looper.loop(Looper.java:130)
01-11 16:00:48.709:I/dalvikvm(18535):位于android.app.ActivityThread.main(ActivityThread.java:3835)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.reflect.Method.Invokenactive(本机方法)
01-11 16:00:48.709:I/dalvikvm(18535):位于java.lang.reflect.Method.invoke(Method.java:507)
01-11 16:00:48.709:I/dalvikvm(18535):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
01-11 16:00:48.709:I/dalvikvm(18535):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
01-11 16:00:48.709:I/dalvikvm(18535):位于dalvik.system.NativeStart.main(本机方法)
01-11 16:00:48.729:W/dalvikvm(18535):抛出内部异常(Ljava/lang/OutOfMemoryError;)时抛出异常(Ljava/lang/OutOfMemoryError;)
01-11 16:00:48.729:W/dalvikvm(18535):无法解析异常捕获列表中的类引用(类索引349,异常Ljava/lang/OutOfMemoryError;)
01-11 16:00:49.209:I/dalvikvm堆(18535):将目标GC堆从25.906MB钳制到24.000MB
01-11 16:00:49.209:D/dalvikvm(18535):GC_并发释放Java中的SAXXML解析器

SAX代表用于XML解析的简单API。这是一个基于事件的XML解析,它一步一步地解析XML文件,非常适合大型XML文件。SAXXML解析器在遇到打开标记、元素或属性时触发事件,并相应地进行解析。建议使用SAXXML解析器来解析Java中的大型XML文件,因为它不需要在Java中加载整个XML文件,并且可以在小部分中读取大型XML文件。Java提供了对SAX解析器的支持,您可以使用SAX解析器解析Java中的任何xml文件,我在这里介绍了使用SAX解析器读取xml文件的示例。在java中使用SAX解析器的一个缺点是,与DOM解析器相比,使用SAX解析器读取java中的XML文件需要更多的代码

DOM和SAXXML解析器之间的区别 以下是Java中DOM解析器和SAX解析器之间的一些高级差异:

1) DOM解析器将整个xml文档加载到内存中,而SAX仅将xml文件的一小部分加载到内存中

2) DOM解析器比SAX更快,因为它可以访问内存中的整个XML文档

3) Java中的SAX解析器是