2012-12-18 19 views
12

我正在读取Stream中的YouTube响应并将其转换为String。使用下面的代码:AbstractStringBuilder上的OutOfMemoryError enlargeBuffer

网址:http://gdata.youtube.com/feeds/api/users/cnn/uploads?&v=2&max-results=25&alt=json

private String convertStreamToString(InputStream is) { 

     BufferedReader reader = new BufferedReader(new InputStreamReader(is)); 
     StringBuilder sb = new StringBuilder(); 

     String line = null; 
     try { 
      while ((line = reader.readLine()) != null) { 
       sb.append(line + "\n"); 
      }   
     } catch (IOException e) { 
      e.printStackTrace(); 
     } finally { 
      try { 
       is.close(); 
      } catch (IOException e) { 
       e.printStackTrace(); 
      } 
     } 
     return sb.toString(); 
    } 

此代码工作在精细中的所有设备,除了Android 4.0的设备。我得到下面的logcat:

java.lang.RuntimeException: An error occured while executing doInBackground() 
     at android.os.AsyncTask$3.done(AsyncTask.java:278) 
     at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273) 
     at java.util.concurrent.FutureTask.setException(FutureTask.java:124) 
     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307) 
     at java.util.concurrent.FutureTask.run(FutureTask.java:137) 
     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 
     at java.lang.Thread.run(Thread.java:856) 
Caused by: java.lang.OutOfMemoryError 
     at java.lang.AbstractStringBuilder.enlargeBuffer(AbstractStringBuilder.java:94) 
     at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:145) 
     at java.lang.StringBuilder.append(StringBuilder.java:216) 
     at com.android.mypack.MyApplications.convertStreamToString(MyApplications.java:959) 
     at com.android.mypack.MyApplications.access$61(MyApplications.java:951) 
     at com.android.mypack.MyApplications$YoutubeTask.doInBackground(MyApplications.java:2303) 
     at com.android.mypack.MyApplications$YoutubeTask.doInBackground(MyApplications.java:1) 
     at android.os.AsyncTask$2.call(AsyncTask.java:264) 
     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 
     ... 5 more 
java.lang.OutOfMemoryError 
     at java.lang.AbstractStringBuilder.enlargeBuffer(AbstractStringBuilder.java:94) 
     at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:145) 
     at java.lang.StringBuilder.append(StringBuilder.java:216) 
     at com.android.mypack.MyApplications.convertStreamToString(MyApplications.java:959) 
     at com.android.mypack.MyApplications.access$61(MyApplications.java:951) 
     at com.android.mypack.MyApplications$YoutubeTask.doInBackground(MyApplications.java:2303) 
     at com.android.mypack.MyApplications$YoutubeTask.doInBackground(MyApplications.java:1) 
     at android.os.AsyncTask$2.call(AsyncTask.java:264) 
     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 
     at java.util.concurrent.FutureTask.run(FutureTask.java:137) 
     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 
     at java.lang.Thread.run(Thread.java:856) 

请帮我解决这个错误。 在此先感谢。

+0

了多少字节从此流来的? – lbalazscs

+0

@lbalazscs请参阅URL,这是我正在处理的响应..我不知道4.0设备有什么问题。 – wolverine

+0

你得到的任何解决方案? – CoronaPintu

回答

1

那么,当虚拟机内存不足时,OutOfMemoryErrors会明显出现。这里重要的一点是,确切的堆栈跟踪可能没有提供信息,因为可能发生另一个线程使用所有内存。或者在这个代码之前在这个线程上发生了一些内存消耗,而这个代码只是“最后一根稻草”。这个URL当然不包含太多的字节,我认为问题出现在另一个地方。

你可以尝试内存分析器: Android ==> Memory Analysing ==> Eclipse memory analyzer?

+0

呵呵,我觉得虚拟机在尝试分配和失败后会抛出这个异常......这意味着堆栈跟踪实际上是有用的,而且,最重要的是,放大缓冲区是非常有意义的一个例外... – edthethird

+0

当然,虚拟机在尝试分配和失败后会抛出这个错误。问题是这种分配是否仅仅是其他分配或根本原因之后的“最后一根稻草”。这个流包含大约110千字节的数据,它不应该太多。 – lbalazscs

+1

啊好的。是的,我们可以肯定地知道这是最后一根稻草。很可能/他可能在其他地方有内存泄漏 – edthethird