0

Android 開発に慣れるために、簡単なアプリの基礎を作ってくれる人を雇って、そこから始めようと思いました。これまでのところ、それは本当にうまくいっています。かなり勉強できました。

私が抱えている問題の 1 つは、アプリのクラッシュの原因となっているバグに関するクラッシュ レポートを受け取り続けていることですが、アプリは Nexus S で完全に動作します! 私はすべてが統一されているiOS開発に慣れています...

次のエラーが報告されています。

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.elan.readerJapanese/com.elan.readerJapanese.Language}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2787)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2803)
at android.app.ActivityThread.access$2300(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2136)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:144)
at android.app.ActivityThread.main(ActivityThread.java:4937)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
 at dalvik.system.NativeStart.main(Native Method)
 Caused by: java.lang.NullPointerException
 at com.elan.readerJapanese.Language.onCreate(Language.java:91)
 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1069)
 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2751)
 ... 11 more'

これは私には理解するのがかなり難しいです。言語クラスの onCreate メソッドで null ポインター例外がスローされることは理解していますが、再現できません。だから私は何が起こっているのか分かりません。これが私の onCreate メソッドのコードです。`public void onCreate(Bundle savedInstanceState) {

   super.onCreate(savedInstanceState);
   setContentView(R.layout.title_list_menu);
   me=this;

   Bundle extras = getIntent().getExtras();
   DatabaseHelper myDatabaseAdapter;
    myDatabaseAdapter = DatabaseHelper.getInstance(me);
   if(extras !=null)
   {


    if(!myDatabaseAdapter.databaseReady()){
        try{
            myDatabaseAdapter.copyDatabase2();
            DatabaseHelper_Spa myDatabaseAdapter_spa = DatabaseHelper_Spa.getInstance(me);
            myDatabaseAdapter_spa.copyDatabaseSpanish2();

        }catch(Exception e){
            e.printStackTrace();
        }
        myDatabaseAdapter.databaseReady();
    }
   }else{
        //myDatabaseAdapter.close();
       if(!myDatabaseAdapter.databaseReady()){
            try{
                myDatabaseAdapter.copyDatabase2();
                DatabaseHelper_Spa myDatabaseAdapter_spa = DatabaseHelper_Spa.getInstance(me);
                myDatabaseAdapter_spa.copyDatabaseSpanish2();

            }catch(Exception e){
                e.printStackTrace();
            }
            myDatabaseAdapter.databaseReady();
        }
       else if(myDatabaseAdapter.getSaveVerse()[0]!=null||!myDatabaseAdapter.getSaveVerse()[0].equals("")){
            String data[]=myDatabaseAdapter.getSaveVerse();
           Intent intent=new Intent(Language.this,  Verse.class);
        intent.putExtra("language",data[0]);
        intent.putExtra("volume_id",data[1]);
        intent.putExtra("chapter",data[2]);
        intent.putExtra("book",data[3]);
        intent.putExtra("book_id",data[4]);
        intent.putExtra("multiple_languages",false);
            startActivity(intent);

        }
    }


  // listImage=new Bitmap[]{BitmapFactory.decodeResource(getResources(), R.drawable.sharing),BitmapFactory.decodeResource(getResources(), R.drawable.contact_us),BitmapFactory.decodeResource(getResources(), R.drawable.about)};
   m_orders = new ArrayList<SettingsObject>();
   this.m_adapter = new AboutAdapter(this, R.layout.language_row, m_orders);
   setListAdapter(this.m_adapter);
   viewOrders = new Runnable(){
       @Override
       public void run() {
           getOrders();
       }
   };

   Thread thread =  new Thread(null, viewOrders, "MagentoBackground");
   thread.start();

}`

誰かが上記のコードに異常があるかどうかを教えてくれれば幸いです。そうでない場合は、このエラーをデバッグするために何ができるかを教えてください。私が言ったように、私のデバイスではエラーが再現されないため、問題が発生しています。

ありがとう!

4

1 に答える 1

0

スタック トレースを見ると、Language.java の 91 行目で例外が発生したことがわかります。

これは、例外出力の最後の部分からわかります。

原因: java.lang.NullPointerException
com.elan.readerJapanese.Language.onCreate (Language.java:91) で
android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1069) で
Android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2751) で
... 11 あと '

行を知らなくても、データベースと関係があると思います。
メソッドgetSaveVerseが null を返すことはありますか?


行番号がそのスタック トレース以降に変更されたと推測しています。行 91 が、そのスタック トレースがmyDatabaseAdapternull である場合にのみ発生する可能性があると言う場合、( else if(myDatabaseAdapter.getSaveVerse()[0]!=null||!myDatabaseAdapter.getSaveVerse()[0].equals("")){) の前の行がクラッシュするためです。

他のオブジェクトを変更しない限り、そのスタックトレースがどのように発生する可能性があるかわかりませんmyDatabaseAdapter

つまりDatabaseHelper、アクティビティが変更されていないことを確認してください

于 2011-06-04T03:44:14.393 に答える