1

これがスプラッシュスクリーンのコードです(それは私の望みではありませんが、クライアントです)-私が行った唯一のこと-soneコードをこのアクティビティへのデータのロードに置き換えるだけです:

public class SplashActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    Retrofit retrofit = new Retrofit.Builder()
            .baseUrl(Constants.API_URL)
            .addConverterFactory(GsonConverterFactory.create())
            .build();

    GetAll getAllProducts = retrofit.create(GetAll.class);
    Call<ArrayList<Products>> call = getAllProducts.getAll(Constants.PARTNER_ID,
            WaterFragment.getMD5Hash(Constants.PARTNER_ID + Constants.API_KEY));
    call.enqueue(new Callback<ArrayList<Products>>() {
        @Override
        public void onResponse(Response<ArrayList<Products>> response, Retrofit retrofit) {
            if (response.body() != null) {
                ActiveAndroid.beginTransaction();
                try {
                    ProductsDMC product;
                    for (Products p : response.body()) {
                        if (new Select().from(ProductsDMC.class).where("product_id = ?", p.id).executeSingle() != null) {
                            product = new Select().from(ProductsDMC.class).where("product_id = ?", p.id).executeSingle();
                            product.price = p.price;
                        } else {
                            product = new ProductsDMC(p.id, p.article, p.title, p.price, p.amount, p.category_id,
                                    p.brand_id, p.description, p.photo[0], p.option != null ? p.option.bottle_price : "0");
                        }
                        product.save();
                    }
                    ActiveAndroid.setTransactionSuccessful();
                } finally {
                    ActiveAndroid.endTransaction();
                }
            }else{
                Toast.makeText(SplashActivity.this, "Try later!", Toast.LENGTH_SHORT).show();
            }
        }
        @Override
        public void onFailure (Throwable t){
            Toast.makeText(SplashActivity.this, "Check your connection!", Toast.LENGTH_SHORT).show();
            Log.d("LoloPolo", t.getMessage().toString());
        }
    });
    Intent intent = new Intent(this, ListOrdersActivity.class);
    startActivity(intent);
    finish();
}
}

今夜、私の crashlytic は、アプリのクラッシュに関する情報を送信します。

Fatal Exception: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.String.toString()' on a null object reference
   at ru.luny.aqualuxe.activity.SplashActivity$3.onFailure(SplashActivity.java:142)
   at retrofit.ExecutorCallAdapterFactory$ExecutorCallback$2.run(ExecutorCallAdapterFactory.java:94)
   at android.os.Handler.handleCallback(Handler.java:739)
   at android.os.Handler.dispatchMessage(Handler.java:95)
   at android.os.Looper.loop(Looper.java:145)
   at android.app.ActivityThread.main(ActivityThread.java:5832)
   at java.lang.reflect.Method.invoke(Method.java)

これについてです:

Toast.makeText(SplashActivity.this, "Try later!", Toast.LENGTH_SHORT).show();

私は本当に理解していません - Toast.makeText().show がどのように NPE を引き起こすか))

私を手伝ってくれますか?

編集

奇妙に思えますが、crashlytics はエラー コード文字列の間違った場所を表示します。トーストではなく、例外からメッセージを取得してデバッグログします。

4

2 に答える 2

3

問題はt.getMessage().toString()

セクションで NPE を取得していonFailure (Throwable t)ます。テストケースの追加""+

 @Override
    public void onFailure (Throwable t){
        Toast.makeText(SplashActivity.this, "Check your connection!", Toast.LENGTH_SHORT).show();
         Log.d("LoloPolo",""+ t.getMessage().toString());
    }
于 2016-02-01T08:27:10.720 に答える
1

NPEが原因であることは非常に問題ですLog.d("LoloPolo", t.getMessage().toString());getMessage()常に有効なオブジェクトを返すとは限りません。印刷tで十分です。例えば

Log.d("LoloPolo", "Error",  t);

こちらをご覧ください)

また、これらのコールバックは で実行されませんUI Thread。「トースト」を表示するためにそれらを使用することはありません。

于 2016-02-01T08:26:10.677 に答える