android - Android 内存不足错误

标签 android out-of-memory arrays

我的应用程序大约 5 天前运行良好!今天,我尝试运行它,结果简直太疯狂了!

在最终抛出内存不足错误之前,我在 logcat 中收到此消息

01-06 04:14:17.088: D/dalvikvm(454): GC_FOR_MALLOC freed 5702 objects / 326856 bytes in 76ms  
01-06 04:14:17.228: D/dalvikvm(454): GC_FOR_MALLOC freed 680 objects / 157944 bytes in 57ms
01-06 04:14:17.228: I/dalvikvm-heap(454): Grow heap (frag case) to 2.860MB for 121834-byte allocation
01-06 04:14:17.288: D/dalvikvm(454): GC_FOR_MALLOC freed 1 objects / 81232 bytes in 60ms
01-06 04:14:17.378: D/dalvikvm(454): GC_FOR_MALLOC freed 5 objects / 192 bytes in 65ms
01-06 04:14:17.388: I/dalvikvm-heap(454): Grow heap (frag case) to 2.957MB for 182746-byte allocation
....and so on...

最后出现这个错误:

01-06 04:24:49.218: E/AndroidRuntime(511): java.lang.OutOfMemoryError
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.AbstractStringBuilder.enlargeBuffer(AbstractStringBuilder.java:97)
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:136)
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.StringBuilder.append(StringBuilder.java:272)
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.io.BufferedReader.readLine(BufferedReader.java:452)
01-06 04:24:49.218: E/AndroidRuntime(511):  at appsbidder.clientstuff.Utils.openURL(Utils.java:285)
01-06 04:24:49.218: E/AndroidRuntime(511):  at appsbidder.clientstuff.Utils.getFeatured(Utils.java:224)
01-06 04:24:49.218: E/AndroidRuntime(511):  at appsbidder.FeaturedAppsActivity$GridViewAdapter.<init>(FeaturedAppsActivity.java:45)
01-06 04:24:49.218: E/AndroidRuntime(511):  at appsbidder.FeaturedAppsActivity.onCreate(FeaturedAppsActivity.java:28)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.os.Looper.loop(Looper.java:123)
01-06 04:24:49.218: E/AndroidRuntime(511):  at android.app.ActivityThread.main(ActivityThread.java:4627)
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.reflect.Method.invokeNative(Native Method)
01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.reflect.Method.invoke(Method.java:521)
01-06 04:24:49.218: E/AndroidRuntime(511):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
01-06 04:24:49.218: E/AndroidRuntime(511):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
01-06 04:24:49.218: E/AndroidRuntime(511):  at dalvik.system.NativeStart.main(Native Method)

我想我已经将范围缩小到了这段代码,但我不知道为什么它不起作用!以前一直工作得很好。我能想到的唯一问题是现在它必须获取比以前更多的数据,所以某个地方发生了溢出,但是在哪里??

public JSONArray openURL(String urlParams, String url)
  {


    HttpsURLConnection connection = null;
    try {
      System.setProperty("http.keepAlive", "false");
      //Create connection
      connection = (HttpsURLConnection)new URL(url).openConnection();
      connection.setRequestMethod("POST");


      connection.setRequestProperty("Content-Type", 
      "application/x-www-form-urlencoded");

      connection.setRequestProperty("Content-Length", "" + 
          Integer.toString(urlParams.getBytes().length));
      connection.setRequestProperty("Content-Language", "en-US"); 


      connection.setUseCaches(false);
      connection.setDoInput(true);
      connection.setDoOutput(true);

      //Send request
      DataOutputStream wr = new DataOutputStream (
                  connection.getOutputStream ());
      wr.writeBytes (urlParams);
      wr.flush();
      wr.close();

      //Get Response    
      InputStream is = connection.getInputStream();
      BufferedReader rd = new BufferedReader(new InputStreamReader(is));
      String line;
      JSONArray ja = new JSONArray();
      while((line = rd.readLine()) != null) {
          ja = new JSONArray(line);
      }
      rd.close();
      return ja;

    } catch (Exception e) {

      e.printStackTrace();
      return null;

    } finally {

      if(connection != null) {
        connection.disconnect(); 
      }

    }

  }

最佳答案

我所看到的你应该看看这个:

      while((line = rd.readLine()) != null) {
          ja = new JSONArray(line);
      }

由于错误是在 readLine 方法调用时引发的。

01-06 04:24:49.218: E/AndroidRuntime(511):  at java.lang.StringBuilder.append(StringBuilder.java:272)
01-06 04:24:49.218: E/A ndroidRuntime(511):  at java.io.BufferedReader.readLine(BufferedReader.java:452)

你应该尝试这个:

char[] buffer = new char[8064];
BufferedReader rd = new BufferedReader(new InputStreamReader(is), buffer.length);

并使用 read 而不是 readLine

rd.read(buffer, 0, buffer.length)

这方面有很多例子。

编辑:

来 self 的旧项目:

readResponse(InputStream inputStream) {

ByteArrayOutputStream stream = new ByteArrayOutputStream ();
byte[] buffer = new byte[8064];

while(true) {
int rd = inputStream.read(buffer)
if(rd == -1)break;
stream.write(buffer, 0 , rd);
}

stream.flush();
buffer = stream.toByteArray();
String response = new String(buffer);
inputStream.close();

return response;
}

关于android - Android 内存不足错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8755828/

相关文章:

android - 如何在Android手机中导入带有私钥的自签名certificate.ca?

android - 多个插入语句android sqlite

java - java 内存不足错误?即使我给了 JVM 足够的初始和最大内存大小

c# - 如何使用 MemoryFailPoint?

c - C语言中如何计算字符串数组元素的个数?

android - ExpandableListView.addHeaderView() 没有保留布局参数

java - 如何解决OutOfMemory错误?

c - C 数组填充

c - 尝试将文件的行扫描到 C 中参差不齐的数组(指针数组)中

android - Intent bundle 中的 Kotlin getParcelableArray 无法将其转换为自定义类型