java.util.ArrayList.add中的java.lang.OutOfMemoryError

时间:2015-04-24 19:34:36

标签: android

我使用以下代码从XML文件中读取项目:

try {
            InputStream istream = assetManager.open("files/Items.xml");
            DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
            Document doc = builder.parse(istream);
            doc.getDocumentElement().normalize();
            NodeList nList = doc.getElementsByTagName("Item");
            System.out.println();
            for (int temp = 0; temp < nList.getLength(); temp++) {
                Node nNode = nList.item(temp);
                if (nNode.getNodeType() == Node.ELEMENT_NODE) {
                    Element eElement = (Element) nNode;
                    String name = getTagValue("Name", eElement);
                    String family = getTagValue("Family", eElement);
                    _shahidViewModels.add(new ShahidViewModel(
                            name,
                            family
                    ));
                }
            }
            istream.close();

        } catch (Exception e) {
            e.printStackTrace();
        }

发生以下错误:

2109-2109/? E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.OutOfMemoryError
            at java.util.ArrayList.add(ArrayList.java:114)
            at addpt.ResultSearchActivity.fillData(ResultSearchActivity.java:76)
            at addpt.ResultSearchActivity.onCreate(ResultSearchActivity.java:54)
            at android.app.Activity.performCreate(Activity.java:5104)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
            at android.app.ActivityThread.access$600(ActivityThread.java:141)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:5041)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
            at dalvik.system.NativeStart.main(Native Method)

这个错误是什么意思? 我该如何解决这个问题?

的build.gradle:

android {
    compileSdkVersion 21
    buildToolsVersion "21.1.1"
    dexOptions {
        javaMaxHeapSize "4g"
    }
    defaultConfig {
        applicationId "ad.dp.t"
        minSdkVersion 14
        targetSdkVersion 21
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

}

请给我一个解决方案。我没有任何想法来解决这个问题

items.xml中的记录数为:150000记录

1 个答案:

答案 0 :(得分:0)

它不是一次性全部拉出所有1000行的好方法,引入自定义xml解析分页或使用第三方(如果有的话)。 从您的文件中加载50个项目,如果用户想要加载的数据多于下次加载的50个项目,还会在活动或片段中覆盖outofMemory以获得安全方面,但最好的方法应该是如果您的列表包含的项目多于删除前50个项目项目和添加新项目,所以你将在列表中保留最多200项,其他安全检查,如开始或结束文件,列表大小应该考虑这样做,你不会出现内存异常