我正在尝试使用以下代码将大文本文件(~2.5 MB)读入我的Android应用程序:
private static String readFile(String path) throws IOException {
FileInputStream stream = new FileInputStream(new File(path));
try {
FileChannel fc = stream.getChannel();
MappedByteBuffer bb = fc.map(FileChannel.MapMode.READ_ONLY, 0, fc.size());
/* Instead of using default, pass in a decoder. */
return Charset.defaultCharset().decode(bb).toString();
}
finally {
stream.close();
}
}
我读到here这是在java中读取文件的最有效方法,但我的应用程序因强制关闭而崩溃,我相信是因为内存不足问题,因为我有这个代码缠绕一个试试块。
我如何读取此内容并且不会让应用程序崩溃?我尝试了几件事,都是相同的,但仅适用于大文件。我无法拆分文件,这在最终的申请中是不可接受的。
更新
以下是我实际阅读文件的部分:
try
{
String str = readFile(filePath);
et.setText(str);
et.setSelection(str.length());
}
catch (Exception ex)
{
et.setText("There was an error reading the file: " + filePath + "\nDetails: " + ex);
}
et
是AutoCompleteTextView
更新2:
我已经运行了adb并找到了以下内容:
04-11 15:26:16.805 20646 20658 W ActivityManager: Activity pause timeout for HistoryRecord{45b37620 com.ultimatecomputerservicesinc.androidhelloworld/.HelloWorld}
04-11 15:26:17.032 20727 20727 D dalvikvm: GC_EXTERNAL_ALLOC freed 1202 objects / 51792 bytes in 66ms
-- snip --
04-11 15:26:20.868 20727 20727 D dalvikvm: GC_EXTERNAL_ALLOC freed 639 objects / 25048 bytes in 38ms
04-11 15:26:20.961 25842 25842 I Process : Sending signal. PID: 25842 SIG: 9
04-11 15:26:21.102 20727 20727 D dalvikvm: GC_EXTERNAL_ALLOC freed 626 objects / 24328 bytes in 93ms
04-11 15:26:21.141 20646 20650 I ActivityManager: Process com.ultimatecomputerservicesinc.androidhelloworld (pid 25842) has died.
信号9是什么意思?
更新3
我的怀疑是正确的,我的内存耗尽了!如何在android上增加JVM大小?
04-12 20:41:48.905 6610 6610 E AndroidRuntime: FATAL EXCEPTION: main
04-12 20:41:48.905 6610 6610 E AndroidRuntime: java.lang.OutOfMemoryError
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.text.PackedIntVector.growBuffer(PackedIntVector.java:257)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.text.PackedIntVector.insertAt(PackedIntVector.java:187)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.text.DynamicLayout.reflow(DynamicLayout.java:336)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.text.DynamicLayout.<init>(DynamicLayout.java:150)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.TextView.makeNewLayout(TextView.java:4987)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.TextView.checkForRelayout(TextView.java:5484)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.TextView.setText(TextView.java:2776)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.TextView.setText(TextView.java:2644)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.EditText.setText(EditText.java:75)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.widget.TextView.setText(TextView.java:2619)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at com.ultimatecomputerservicesinc.androidhelloworld.HelloWorld$1$1.run(HelloWorld.java:183)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:587)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:92)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.os.Looper.loop(Looper.java:143)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:4701)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at java.lang.reflect.Method.invokeNative(Native Method)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:521)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-12 20:41:48.905 6610 6610 E AndroidRuntime: at dalvik.system.NativeStart.main(Native Method)
答案 0 :(得分:0)
您的应用实际上没有捕获任何异常,它只是在崩溃时清理资源。
将try(异常e){}添加到try / finally以捕获异常。
我有一个应用程序,我曾经加载1MB文件,这不是一个问题(虽然是一个DOM解析器)
答案 1 :(得分:0)
请在日志中打印异常详细信息并发布结果。做这样的事情:
catch( Exception err) {
Log.e("There was an error reading the file", err);
}
这应该会给你一些更有意义的消息,解释发生的事情以及正在执行的方法的痕迹。
然后,我们可能会进一步帮助您。
当我使用DOM解析器解析2.5 MB文件时,我的内存不足...但我不认为你这样做,所以这可能是另一个问题。无论如何,我通过将数据分成几个文件并一次解析一个来解决我的问题。 〜1MB是文件的“安全”大小。