FileWriter可能会也可能不会创建文件?

时间:2013-08-21 01:02:27

标签: java android

我正在为我的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)

1 个答案:

答案 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所说,记得添加写入权限