我遇到了一个让我发疯的问题 xD ...(首先:大家好!出于某种原因,我不能在编辑 oO 的帖子开头添加“大家好”...)
用例如下:我在项目的原始文件夹中存储了一个 xml 文件。xml 文件看起来像这样:
<myxml ....>Some text<innerelement ... /></myxml>
我知道有一个名为 xml 的文件夹,但我需要的是一个字符串 - 而不是 XmlResourceParser(调用 context.getResources().getXml(id) 时会得到它)。
现在,我加载这个原始 xml 文件的方法是:
context.getResources().openRawResource(R.raw.myfile)
这将返回一个 InputStream,然后我尝试使用以下代码将其转换为字符串:
try {
byte[] buffer = new byte[stream.available()];
stream.read(buffer);
stream.close();
return new String(buffer);
} catch (IOException e) {
// Error handling
}
如果我现在将生成的字符串打印到 logcat,我得到的只是一堆正方形,分布在几行上。
所以我想我一定是遗漏了一些东西......我已经尝试了几种将这个输入流转换为 String 的方法,并且所有这些方法都得到了相同的结果(见上图)......
在此先感谢并致以最诚挚的问候,
扎伊诺迪斯
2011 年 11 月 12 日更新
我尝试使用扩展名 .txt 而不是 .xml 将 xml 文件保存在原始文件夹中。现在转换失败并出现 OutOfMemory 异常 oO。我尝试了不同的方法来使用来自该线程的建议来转换数据- 所有这些都导致 OutOfMemoryException:
11-12 06:09:22.671: I/TestRunner(652): java.lang.OutOfMemoryError
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.expandBuffer(Scanner.java:2183)
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.readMore(Scanner.java:2143)
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.findPostDelimiter(Scanner.java:2121)
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.setTokenRegion(Scanner.java:2031)
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.next(Scanner.java:1017)
11-12 06:09:22.671: I/TestRunner(652): at java.util.Scanner.next(Scanner.java:993)
11-12 06:09:22.671: I/TestRunner(652): at de.softcon.mobileapp.framework.core.configuration.utility.StringUtils.InputStreamToString(StringUtils.java:69)
11-12 06:09:22.671: I/TestRunner(652): at de.softcon.mobileoffences.domainmodel.serialization.test.CorpusDelictiFactoryTest.testSerialization(CorpusDelictiFactoryTest.java:32)
11-12 06:09:22.671: I/TestRunner(652): at java.lang.reflect.Method.invokeNative(Native Method)
11-12 06:09:22.671: I/TestRunner(652): at java.lang.reflect.Method.invoke(Method.java:507)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestCase.runTest(TestCase.java:154)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestCase.runBare(TestCase.java:127)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestResult$1.protect(TestResult.java:106)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestResult.runProtected(TestResult.java:124)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestResult.run(TestResult.java:109)
11-12 06:09:22.671: I/TestRunner(652): at junit.framework.TestCase.run(TestCase.java:118)
11-12 06:09:22.671: I/TestRunner(652): at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:169)
11-12 06:09:22.671: I/TestRunner(652): at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:154)
11-12 06:09:22.671: I/TestRunner(652): at android.test.InstrumentationTestRunner.onStart(InstrumentationTestRunner.java:529)
11-12 06:09:22.671: I/TestRunner(652): at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1448)