我正在为我的Kindle Fire开发应用程序,我只是想测试一个文件,并暂时再次打开它。保存过程显示工作正常,但每当我尝试按下加载按钮时,当我尝试使用它时,它会抛出FileNotFoundExeception
和随后的NullPointerExeception
。
我说它看起来工作正常,因为我实际上无法查看我的kindle上的目录,当我按下保存按钮时没有抛出任何错误。该目录列为/mnt/sdcard/Android/data/portalboat.concept/files/BLUH.txt
,但只要我点击/mnt/sdcard
目录中的Android文件夹,它就会将我重定向到/sdcard/Android
,而不是/mnt/sdcard/Android
。在我可以查看的完整目录中没有任何内容,但我不确定它是否是同一个目录。
我已经运行mkdirs()
和createNewFile(),
并且没有抛出任何错误,因此可以认为正在创建该文件。但显然它不是,因为当我尝试使用EXACT SAME File类创建行加载它时,我得到一个FileNotFoundExeception。
有没有人知道造成这种情况的原因?
SaveText是保存函数,LoadText显然是加载函数。
public void SaveText(View view)
{
File CS_File = new File(this.getExternalFilesDir(null), "BLUH.txt");
CS_File.mkdirs();
try {
CS_File.createNewFile();
FileWriter CS_FileWriter = new FileWriter(CS_File);
EditText CS_EditText = (EditText)findViewById(R.id.createscreen_edittext);
String CS_MessageTemp = CS_EditText.getText().toString();
CS_FileWriter.write(CS_MessageTemp);
CS_FileWriter.close();
}
catch (IOException e) {
Log.w("WriteFile", "Error writing" + CS_File, e);
}
TextView CS_TestText = (TextView)findViewById(R.id.createscreen_testtext);
CS_TestText.setText(CS_File.toString());
}
public void LoadText(View view)
{
File CS_File = new File(this.getExternalFilesDir(null), "BLUH.txt");
String CS_Message = "";
try {
FileInputStream CS_FileInputS = new FileInputStream(CS_File);
CS_FileInputS.read(CS_Message.getBytes(), 0, CS_Message.length());
CS_FileInputS.close();
} catch (IOException e) {
Log.w("LoadFile", "Error loading" + CS_File, e);
}
Intent INT_DisplayScreen = new Intent(this, ACT_DisplayScreen.class);
INT_DisplayScreen.putExtra(EXTRA_MESSAGE, CS_Message);
startActivity(INT_DisplayScreen);
}
The error dump.(链接完全转储)
08-20 17:23:31.349: W/LoadFile(1399): Error loading/mnt/sdcard/Android/data/portalboat.concept/files/BLUH.txt
08-20 17:23:31.349: W/LoadFile(1399): java.io.FileNotFoundException: /mnt/sdcard/Android/data/portalboat.concept/files/BLUH.txt: open failed: ENOENT (No such file or directory)
08-20 17:23:31.349: W/LoadFile(1399): at libcore.io.IoBridge.open(IoBridge.java:406)
08-20 17:23:31.349: W/LoadFile(1399): at java.io.FileInputStream.<init>(FileInputStream.java:78)
08-20 17:23:31.349: W/LoadFile(1399): at portalboat.concept.ACT_CreateScreen.LoadText(ACT_CreateScreen.java:86)
08-20 17:23:31.349: W/LoadFile(1399): at java.lang.reflect.Method.invokeNative(Native Method)
08-20 17:23:31.349: W/LoadFile(1399): at java.lang.reflect.Method.invoke(Method.java:511)
08-20 17:23:31.349: W/LoadFile(1399): at android.view.View$1.onClick(View.java:3068)
08-20 17:23:31.349: W/LoadFile(1399): at android.view.View.performClick(View.java:3540)
08-20 17:23:31.349: W/LoadFile(1399): at android.view.View$PerformClick.run(View.java:14167)
08-20 17:23:31.349: W/LoadFile(1399): at android.os.Handler.handleCallback(Handler.java:605)
答案 0 :(得分:0)
您可以使用DMS检查文件是否已成功创建。
尝试以下内容阅读文件
File file = new File(Environment.getExternalStorageDirectory(),filename);
if (file !=null) {// reading file from SD card
BufferedReader reader = new BufferedReader(new FileReader(file));
String line = "";
while((line = reader.readLine()) != null){
// process line here
}
reader.close();
}
正如Roddy所说,记得添加写入权限