Java ArrayAdapter可能导致应用程序崩溃

Java ArrayAdapter可能导致应用程序崩溃,java,android,listview,android-asynctask,android-arrayadapter,Java,Android,Listview,Android Asynctask,Android Arrayadapter,我在继续使用我的应用程序时遇到问题。我刚开始开发这个应用程序,到目前为止只花了大约15个小时。但我遇到了一个障碍。通常我能用谷歌搜索障碍,我的大部分答案都来自这个论坛 所以我希望我能找到解决办法。下面是我的活动java文件。这就是问题所在,因为它以前运作良好。我在使用阵列适配器显示列表时遇到了很多麻烦 public class Favorites extends Activity{ UserFunctions userFunctions = new UserFunctions(); Array

我在继续使用我的应用程序时遇到问题。我刚开始开发这个应用程序,到目前为止只花了大约15个小时。但我遇到了一个障碍。通常我能用谷歌搜索障碍,我的大部分答案都来自这个论坛

所以我希望我能找到解决办法。下面是我的活动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);
        }
    }
公共类收藏夹扩展活动{
UserFunctions UserFunctions=新的UserFunctions();
ArrayList zipcodes=新的ArrayList(0);
ArrayAdapter ArrayAdapter 1=
新的ArrayAdapter(这是android.R.layout.activity\u list\u项,zipcodes);
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.favoritespage);
新建DownloadDataTask().execute();
}
@凌驾
公共布尔onCreateOptions菜单(菜单){
//为菜单充气;这会将项目添加到操作栏(如果存在)。
getMenuInflater().充气(R.menu.activity\u主屏幕,菜单);
返回true;
}
私有类DownloadDataTask扩展了AsyncTask{
@凌驾
受保护的ArrayList doInBackground(JSONArray…参数){
JSONArray json=userFunctions.ziplistrequest(“37.5”、“140.45”、“20”);
for(int i=0;i
}

现在我不知道到底是什么导致了我的问题。我试过用谷歌搜索追踪的各个部分,但没有结果。我发现很多关于它的文章,但每一篇都与我的完全不同,所以他们的解决方案对我不起作用。下面是线索

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
01-29 07:55:47.753:E/AndroidRuntime(3723):致命异常:主
01-29 07:55:47.753:E/AndroidRuntime(3723):java.lang.RuntimeException:无法实例化活动组件信息{com.example.lo/com.example.lo.Favorites}:java.lang.IllegalStateException:onCreate()之前的活动无法使用系统服务
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
01-29 07:55:47.753:E/AndroidRuntime(3723):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.ActivityThread.access$600(ActivityThread.java:141)
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.os.Handler.dispatchMessage(Handler.java:99)上
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.os.Looper.loop(Looper.java:137)
01-29 07:55:47.753:E/AndroidRuntime(3723):位于android.app.ActivityThread.main(ActivityThread.java:5039)
01-29 07:55:47.753:E/AndroidRuntime(3723):位于java.lang.reflect.Method.Invokenactive(本机方法)
01-29 07:55:47.753:E/AndroidRuntime(3723):在java.lang.reflect.Method.invoke(Method.java:511)
01-29 07:55:47.753:E/AndroidRuntime(3723):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-29 07:55:47.753:E/AndroidRuntime(3723):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-29 07:55:47.753:E/AndroidRuntime(3723):在dalvik.system.NativeStart.main(本机方法)
01-29 07:55:47.753:E/AndroidRuntime(3723):由以下原因引起:java.lang.IllegalStateException:onCreate()之前的活动无法使用系统服务
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.Activity.getSystemService(Activity.java:4463)上
01-29 07:55:47.753:E/AndroidRuntime(3723):位于android.widget.ArrayAdapter.init(ArrayAdapter.java:310)
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.widget.ArrayAdapter.(ArrayAdapter.java:104)
01-29 07:55:47.753:E/AndroidRuntime(3723):在com.example.lo.Favorites.(Favorites.java:33)
01-29 07:55:47.753:E/AndroidRuntime(3723):位于java.lang.Class.newInstanceImpl(本机方法)
01-29 07:55:47.753:E/AndroidRuntime(3723):位于java.lang.Class.newInstance(Class.java:1319)
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.Instrumentation.newActivity(Instrumentation.java:1054)上
01-29 07:55:47.753:E/AndroidRuntime(3723):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
01-29 07:55:47.753:E/AndroidRuntime(3723):。。。还有11个

在此期间,我会设法解决这个问题。我想我是唯一一个宁愿编程而不愿看超级碗赛的人:P

在你们班上名列前茅,保持领先

ArrayAdapter<String> arrayAdapter1; 
ArrayAdapter ArrayAdapter 1;
然后移动其余部分,使其看起来像这样:

arrayAdapter1 = new ArrayAdapter<String>(Favorites.this,android.R.layout.activity_list_item,zipcodes);
arrayAdapter1=新的ArrayAdapter(收藏夹、android.R.layout.activity\u列表项目、zipcodes);
onCreate()
或在
onPostExecute()
中,具体取决于您想要对数据执行的操作


引发异常是因为适配器(以及许多Android组件)需要在活动中初始化某些(幕后)东西。但是,在调用
活动
onCreate()
之前,这些事情不会发生,因为
onCreate()
是活动的开始。

问题是这一行:

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