Android 安卓随机下载图片失败

Android 安卓随机下载图片失败,android,bitmap,android-asynctask,Android,Bitmap,Android Asynctask,我想我的错误日志会清楚地描述我的问题 我使用Async在产品展示中下载了一些图像。但当下载(可能更大)图像时,应用程序被迫关闭,注意:其他一些产品可以正常下载并显示。 这是我在asynctask中的一些代码,我在doInBackground中执行了DownloadImage(URL),并将其存储在bitmapArray private Bitmap DownloadImage(String URL) { Bitmap bitmap = null; InputStream in = null; t

我想我的错误日志会清楚地描述我的问题

我使用Async在产品展示中下载了一些图像。但当下载(可能更大)图像时,应用程序被迫关闭,注意:其他一些产品可以正常下载并显示。

这是我在asynctask中的一些代码,我在doInBackground中执行了DownloadImage(URL),并将其存储在bitmapArray

private Bitmap DownloadImage(String URL) {
Bitmap bitmap = null;
InputStream in = null;
try {
    in = OpenHttpConnection(URL);
    BufferedInputStream bis = new BufferedInputStream(in, 32 * 4096);

    ByteArrayBuffer baf = new ByteArrayBuffer(50);
    int current = 0;
    while ((current = bis.read()) != -1) {
    baf.append((byte) current);
    }
    byte[] imageData = baf.toByteArray();
    bitmap = BitmapFactory.decodeByteArray(imageData,0,imageData.length);


    in.close();
    } catch (IOException e1) {
    e1.printStackTrace();
    }
    return bitmap;
}
Log.txt

02-21 06:54:35.982: E/AndroidRuntime(2026): FATAL EXCEPTION: AsyncTask #3
02-21 06:54:35.982: E/AndroidRuntime(2026): java.lang.RuntimeException: An error occured while executing doInBackground()
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.os.AsyncTask$3.done(AsyncTask.java:299)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.FutureTask.run(FutureTask.java:137)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.lang.Thread.run(Thread.java:856)
02-21 06:54:35.982: E/AndroidRuntime(2026): Caused by: java.lang.OutOfMemoryError
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.graphics.BitmapFactory.nativeDecodeByteArray(Native Method)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.graphics.BitmapFactory.decodeByteArray(BitmapFactory.java:426)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.graphics.BitmapFactory.decodeByteArray(BitmapFactory.java:444)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at com.nazartt.angtrading.ShowCase$task.DownloadImage(ShowCase.java:201)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at com.nazartt.angtrading.ShowCase$task.doInBackground(ShowCase.java:129)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at com.nazartt.angtrading.ShowCase$task.doInBackground(ShowCase.java:1)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at android.os.AsyncTask$2.call(AsyncTask.java:287)
02-21 06:54:35.982: E/AndroidRuntime(2026):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)

如果您正在下载多个图像,那么您应该使用下面给出的一些缓存算法,这样您就可以轻松地缓存图像并从缓存中加载


  • 你必须回收位图。位图实现是本机的,因此java对象很小,不适合进行java垃圾收集,但内存仍然是分配的。看看Bitmap.recycle()

    我确信这句话
    BufferedInputStream(in,32*4096)导致了一个问题很抱歉,我刚刚使用了一些教程代码,现在该怎么办?我试着输入更小或更大的数字,但仍然不起作用。我发现问题只发生在我的位图阵列接收到一些大尺寸图像时,你知道吗?