0

アプリを進めるのに問題があります。私はアプリの開発を始めたばかりで、これまでに約 15 時間しか関与していません。しかし、私は思わぬ障害にぶつかりました。通常、思わぬ問題を Google で検索できますが、ほとんどの回答はこのフォーラムから得られます。

ですから、これに対する解決策を見つけられることを願っています。以下は私のアクティビティJavaファイルです。これは、以前は正常に機能していたため、問題が発生した場所です。アレイ アダプターを使用してリストを表示する際に、多くの問題が発生しています。

public class Favorites extends Activity{
UserFunctions userFunctions  = new UserFunctions();
ArrayList<String> zipcodes = new ArrayList<String>(0);
ArrayAdapter<String> arrayAdapter1 =      
         new ArrayAdapter<String>(this,android.R.layout.activity_list_item,zipcodes);

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

    new DownloadDataTask().execute();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.activity_main_screen, menu);
    return true;
}

   private class DownloadDataTask extends AsyncTask<JSONArray, JSONArray, ArrayList<String> > {


        @Override
        protected ArrayList<String> doInBackground(JSONArray... params) {
            JSONArray json = userFunctions.ziplistrequest("37.5", "140.45", "20");

            for(int i=0; i < json.length() ; i++) {
                JSONObject jarray = null;
                try {
                    jarray = json.getJSONObject(i);
                    String zip = jarray.getString("ZIPCODE");
                    zipcodes.add(zip);
                    arrayAdapter1.add(zip);
                    Log.d(zip,"Output");
                } catch (JSONException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            return zipcodes;
        }   
        protected void onPostExecute(){
            ListView listView = (ListView) findViewById(R.id.listView1);
            listView.setAdapter(arrayAdapter1);
        }
    }

}

今、何が問題を引き起こしているのか正確にはわかりません。トレースの個々の部分をグーグルで検索してみましたが、役に立ちませんでした。私はそれに関する多くの記事を見つけましたが、それぞれが私のものとはまったく異なるものを提示しているため、それらの解決策は私にとってはうまくいきません. 以下、跡です。

01-29 07:55:47.753: E/AndroidRuntime(3723): FATAL EXCEPTION: main
01-29 07:55:47.753: E/AndroidRuntime(3723): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.lo/com.example.lo.Favorites}: java.lang.IllegalStateException: System services not available to Activities before onCreate()
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.os.Looper.loop(Looper.java:137)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread.main(ActivityThread.java:5039)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at java.lang.reflect.Method.invokeNative(Native Method)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at java.lang.reflect.Method.invoke(Method.java:511)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at dalvik.system.NativeStart.main(Native Method)
01-29 07:55:47.753: E/AndroidRuntime(3723): Caused by: java.lang.IllegalStateException: System services not available to Activities before onCreate()
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.Activity.getSystemService(Activity.java:4463)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.widget.ArrayAdapter.init(ArrayAdapter.java:310)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.widget.ArrayAdapter.<init>(ArrayAdapter.java:104)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at com.example.lo.Favorites.<init>(Favorites.java:33)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at java.lang.Class.newInstanceImpl(Native Method)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at java.lang.Class.newInstance(Class.java:1319)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
01-29 07:55:47.753: E/AndroidRuntime(3723):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
01-29 07:55:47.753: E/AndroidRuntime(3723):     ... 11 more

それまでの間、これを修正しようとします。スーパーボウルを見るよりもプログラミングしたいのは私だけだと思います :P

4

2 に答える 2

1

あなたのクラスのトップで、

ArrayAdapter<String> arrayAdapter1; 

残りを次のように移動します。

arrayAdapter1 = new ArrayAdapter<String>(Favorites.this,android.R.layout.activity_list_item,zipcodes);

toonCreate()または in onPostExecute()、データで正確に何をしたいかによって異なります。

Adapters (および多くの Android コンポーネント) はアクティビティで初期化された特定の (舞台裏の) ものを必要とするため、例外がスローされます。ただし、アクティビティのライフサイクルの始まりであるため、これらActivityのことonCreate()は が呼び出される前には発生しません。onCreate()

于 2013-02-03T23:39:08.117 に答える
0

問題は次の行です。

ArrayAdapter<String> arrayAdapter1 =      
     new ArrayAdapter<String>(this,android.R.layout.activity_list_item,zipcodes);

アクティビティが適切に初期化さthisれるまで、呼び出しで使用することはできません。内部( を呼び出した後、または内部でnew ArrayAdapter()に割り当てることができます。これは、 in ではなく内部で行う方がよいでしょう。arrayAdapter1onCreate()super.onCreate()DownloadDataTaskonPostExecutedoInBackground

于 2013-02-03T23:40:54.490 に答える