2

次のような ZipFile を作成しているときに、次のスタックを取得します。

final ZipFile zipFile = new ZipFile(mDownloadedFile);

エラー:

java.lang.RuntimeException: An error occured while executing doInBackground()
    at android.os.AsyncTask$3.done(AsyncTask.java:299)
    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 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.ArrayIndexOutOfBoundsException: length=4096; regionStart=0; regionLength=-60060589
    at java.util.Arrays.checkOffsetAndCount(Arrays.java:1731)
    at libcore.io.IoBridge.read(IoBridge.java:427)
    at java.io.RandomAccessFile.read(RandomAccessFile.java:290)
    at java.util.zip.ZipFile$RAFStream.read(ZipFile.java:407)
    at java.io.InputStream.read(InputStream.java:163)
    at java.io.BufferedInputStream.fillbuf(BufferedInputStream.java:142)
    at java.io.BufferedInputStream.read(BufferedInputStream.java:309)
    at libcore.io.Streams.readFully(Streams.java:81)
    at java.util.zip.ZipEntry.<init>(ZipEntry.java:353)
    at java.util.zip.ZipFile.readCentralDir(ZipFile.java:365)
    at java.util.zip.ZipFile.<init>(ZipFile.java:132)
    at java.util.zip.ZipFile.<init>(ZipFile.java:103)
    at xxx.android.task.xxTask.unzipFile(xxTask.java:250)
    at xxx.android.task.xxTask.extract(xxTask.java:197)
    at xxx.android.task.xxTask.doInBackground(xxTask.java:157)
    at xxx.android.task.xxTask.doInBackground(xxTask.java:53)
    at android.os.AsyncTask$2.call(AsyncTask.java:287)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
    ... 4 more

エラーを再現することはできません。世界のどこかで起こったライブ アプリで、メール スタック トラッカーを介してこのエラーを受け取りました。

負の regionLength=-60060589? があります。これはどのように可能ですか?ストレージ上で既に削除されたファイルのファイルを作成しようとすると、この問題が発生する可能性はありますか? のような: ダウンロード - 何らかの理由で失敗し、ファイルを削除します。 - 再度ダウンロードします - クラッシュします。

編集: mDownloadedFile は、ダウンロードが開始される前に作成されるファイルです。通常は new で作成されますが、リトライの場合 (何らかの理由でダウンロードに失敗した場合) は、そのファイルでタスクを再起動します。この部分は不要なので削除しました。これがエラーである可能性がある場合は、既に修正しましたが、誰かが何か違うことを知っている可能性があります。

いくつかの想像?ありがとう

4

2 に答える 2

0

いくつかの想像?

ここに私の試みがあります:
ファイルの長さを に保存する場合、int考えられる原因の 1 つは、より大きなサイズのファイルが保持できる最大許容値を超えている可能性がありますint。つまり、 の数値regionLengthは で表すには大きすぎますint
これは、サイズが数 GB などの大きな zip ファイルでテストすることで確認できます。その場合は、長さを に保持するlongことで問題を解決できます。

于 2013-07-01T11:00:33.157 に答える