0

Androidの内部ストレージを使用してtxtファイルにデータを書き込もうとしましたが、mainActivity.javaの「buttonClicked」関数でコードを直接使用すると正常に動作しますが、クラスのメソッドをエミュレーターで呼び出そうとすると正常に動作しますクラッシュします。ありがとう!

public class MainActivity extends Activity {

        // the class object ----------------------
    FileHandler myFileHandler = new FileHandler();
    public static final String FILENAME = "myFile.txt";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }


   public void buttonClicked(View view) {
       // Call the method in the Filehandler Class 
       myFileHandler.saveData(FILENAME);
} ...

fileHandler クラス

public class FileHandler extends Activity {
    private static final String TAG = MainActivity.class.getName();

    FileHandler() { 
    }


    void saveData(String FILENAME) {

        Log.d(TAG, FILENAME);

        try {
               OutputStreamWriter outputStreamWriter = new OutputStreamWriter(openFileOutput(FILENAME, Context.MODE_PRIVATE));
               outputStreamWriter.write("hallo welt");
               outputStreamWriter.close();
           }
           catch (IOException e) {
               Log.e(TAG, "File write failed: " + e.toString());
           }
    } ...

これはうまくいきます…</p>

public void buttonClicked(View view) {



       myFileHandler.saveData(FILENAME);

        try {
               OutputStreamWriter outputStreamWriter = new OutputStreamWriter(openFileOutput(FILENAME, Context.MODE_PRIVATE));
               outputStreamWriter.write("hallo welt");
               outputStreamWriter.close();
           }
           catch (IOException e) {
               Log.e(TAG, "File write failed: " + e.toString());
           } 

    }

すべてのクラスが正しくインポートされ、ログ cat からのエラー

    11-11 11:49:22.646: E/AndroidRuntime(833): FATAL EXCEPTION: main
11-11 11:49:22.646: E/AndroidRuntime(833): java.lang.IllegalStateException: Could not execute method of the activity
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.view.View$1.onClick(View.java:2072)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.view.View.performClick(View.java:2408)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.view.View$PerformClick.run(View.java:8816)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.os.Handler.handleCallback(Handler.java:587)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.os.Handler.dispatchMessage(Handler.java:92)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.os.Looper.loop(Looper.java:123)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.app.ActivityThread.main(ActivityThread.java:4627)
11-11 11:49:22.646: E/AndroidRuntime(833):  at java.lang.reflect.Method.invokeNative(Native Method)
11-11 11:49:22.646: E/AndroidRuntime(833):  at java.lang.reflect.Method.invoke(Method.java:521)
11-11 11:49:22.646: E/AndroidRuntime(833):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
11-11 11:49:22.646: E/AndroidRuntime(833):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
11-11 11:49:22.646: E/AndroidRuntime(833):  at dalvik.system.NativeStart.main(Native Method)
11-11 11:49:22.646: E/AndroidRuntime(833): Caused by: java.lang.reflect.InvocationTargetException
11-11 11:49:22.646: E/AndroidRuntime(833):  at com.example.iLoveMyMobile.MainActivity.buttonClicked(MainActivity.java:55)
11-11 11:49:22.646: E/AndroidRuntime(833):  at java.lang.reflect.Method.invokeNative(Native Method)
11-11 11:49:22.646: E/AndroidRuntime(833):  at java.lang.reflect.Method.invoke(Method.java:521)
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.view.View$1.onClick(View.java:2067)
11-11 11:49:22.646: E/AndroidRuntime(833):  ... 11 more
11-11 11:49:22.646: E/AndroidRuntime(833): Caused by: java.lang.NullPointerException
11-11 11:49:22.646: E/AndroidRuntime(833):  at android.content.ContextWrapper.openFileOutput(ContextWrapper.java:158)
11-11 11:49:22.646: E/AndroidRuntime(833):  at com.example.iLoveMyMobile.FileHandler.saveData(FileHandler.java:36)
11-11 11:49:22.646: E/AndroidRuntime(833):  ... 15 more
4

2 に答える 2

0

問題context object became null

OutputStreamWriter outputStreamWriter = new OutputStreamWriter(openFileOutput(FILENAME, Context.MODE_PRIVATE)); 

openFileOutputこれは実際にはthis.openFileOutput SoメソッドがMainActivityopenFileOutputの同じコンテキストを参照していましたが、別のアクティビティを入れたときにコンテキストをnullとして取得しています。context パラメーターを渡すことで、メソッドを書き直すことができます。

void saveData(String FILENAME, Context mContext) {

        Log.d(TAG, FILENAME);

        try {
               OutputStreamWriter outputStreamWriter = new OutputStreamWriter(mContext.openFileOutput(FILENAME, Context.MODE_PRIVATE));
               outputStreamWriter.write("hallo welt");
               outputStreamWriter.close();
           }
           catch (IOException e) {
               Log.e(TAG, "File write failed: " + e.toString());
           }
    }

呼び出し中に次のように書くことができます

myFileHandler.saveData(FILENAME, this);
于 2013-11-11T11:18:28.060 に答える
0

私があなたを正しく理解していれば、MainActivity の FileHandler クラスでメソッドを使用しようとしています。FileHandler は、ファイルの保存に使用する単なるオブジェクトである場合、Activity を拡張しないでください。

extends Activity を削除し、Mainactivity を FileHandler クラスのコンテキストとして使用します。

    FileHandler f = new FileHandler(Mainactivity.class);

そして FileHandler で

    context.openFileOutput()
于 2013-11-11T11:19:12.880 に答える