0

私のユーザーは、WiFi を使用して JSON ファイルをダウンロードすると、アプリは魅力的に動作するが、データ接続 (GPRS、3G、3.5G など) を使用して同じファイルをダウンロードしようとすると、アプリが強制終了することを報告しています。すべてのタイプのスマートフォンで発生するわけではありません。たとえば、私の LG Optimus Black では発生しません。

このファイルを取得するには、AsyncTask を使用します。

private class GetData extends AsyncTask<Void, Void, Void> {
        protected Void doInBackground(Void... args) {

            DefaultHttpClient httpclient = new DefaultHttpClient();
            try {

                HttpGet httpget = new HttpGet("http://url.com);
                HttpResponse response = httpclient.execute(httpget);
                strPlayers = inputStreamToString(response.getEntity().getContent()).toString();
            }
            catch (IOException e) { e.printStackTrace(); } 
            finally { httpclient.getConnectionManager().shutdown(); }

           return null;
        }

        protected void onPostExecute(Void result) {

            Players players = new Gson().fromJson(strPlayers, Players.class);

            quantity_darkmatter.setText(String.valueOf(players.userName));

        }
    }

ここに StackTrace() があります

java.lang.RuntimeException: Unable to start activity ComponentInfo{carl.fri.fer.omegan/carl.fri.fer.omegan.Research}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1659)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1675)
at android.app.ActivityThread.access$1500(ActivityThread.java:121)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:943)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3701)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:624)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at carl.fri.fer.omegan.Research.onStart(Research.java:613)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1129)
at android.app.Activity.performStart(Activity.java:3791)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1632)
... 11 more

何が問題になる可能性がありますか?

4

1 に答える 1

0

非 WIFI の場合、接続にかなり時間がかかる可能性があるため、接続タイムアウトの問題である可能性があります。その場合、strPlayers は空白になり、onPostExecute にエラー処理がないため、Gson.fromJson にヒックアップが発生し、例外がスローされる可能性があります。 ... strPlayers!=null をテストしてから解析するか、try-catch ブロックに入れて、何らかの例外がスローされるかどうかを確認してください。

doInBackground 関数に e.printStackTrace() の出力はありますか?

于 2012-04-23T10:51:41.197 に答える