【问题标题】:Unable to start activity, NullPointerException - Android无法启动活动,NullPointerException - Android
【发布时间】:2013-10-27 20:21:16
【问题描述】:

MessagesActivity.java

package org.example.fbapp;

import java.io.FileNotFoundException;
import java.io.IOException;
import java.net.MalformedURLException;
import java.util.ArrayList;
import java.util.HashMap;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import com.facebook.android.AsyncFacebookRunner;
import com.facebook.android.Facebook;
import com.facebook.android.FacebookError;
import com.facebook.android.AsyncFacebookRunner.RequestListener;

import android.app.ListActivity;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.widget.ArrayAdapter;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.Toast;

public class MessagesActivity extends ListActivity {

    // Your Facebook APP ID
    private static String APP_ID = "5496*******054";

    // JSON Node names
    private static final String TAG_DATA = "data";
    private static final String TAG_MESSAGE = "message";

    // data JSONArray
    JSONArray data = null;

    // Instance of Facebook Class
    @SuppressWarnings("deprecation")
    private Facebook facebook = new Facebook(APP_ID);
    @SuppressWarnings("deprecation")
    private AsyncFacebookRunner mAsyncRunner;
    String FILENAME = "AndroidSSO_data";
    private SharedPreferences mPrefs;

    // Hashmap for ListView
    ArrayList<HashMap<String, String>> messages = new ArrayList<HashMap<String, String>>();
    private ListView lv;

    ListView mylistview;
    ArrayList<String> array_months;
    ArrayAdapter<String> listAdapter;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle icicle) {
        super.onCreate(icicle);
        setContentView(R.layout.contacts_view);

        ListAdapter adapter = createAdapter();
        setListAdapter(adapter);
    }

    /**
     * Creates and returns a list adapter for the current list activity
     * 
     * @return
     */
    @SuppressWarnings("deprecation")
    protected ListAdapter createAdapter()
    {
        mAsyncRunner.request("203153109726651/feed", new RequestListener() {
            @Override
            public void onComplete(String response, Object state) {
                Log.d("GET POSTS", response);
                String json = response;

                try {

                    // Facebook Profile JSON data
                    JSONObject obj = new JSONObject(json);
                    JSONArray finalObj = obj.getJSONArray("data");
                    array_months = new ArrayList<String>();

                    for (int i = 0; i < finalObj.length(); i++) {

                        final String message = finalObj.getJSONObject(i)
                                .getString("message");

                        array_months.add(message);
                    }



                } catch (JSONException e) {
                    e.printStackTrace();
                }

        }

            @Override
            public void onIOException(IOException e, Object state) {
            }

            @Override
            public void onFileNotFoundException(FileNotFoundException e,
                    Object state) {
            }

            @Override
            public void onMalformedURLException(MalformedURLException e,
                    Object state) {
            }

            @Override
            public void onFacebookError(FacebookError e, Object state) {
            }
        });

        // Create a simple array adapter (of type string) with the test values
        //ListAdapter adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, adapter);
        ListAdapter adapter = new ArrayAdapter<String>(MessagesActivity.this,
                android.R.layout.simple_list_item_1, array_months);
        //setListAdapter(listAdapter);
        return adapter;
    }
}

我的主活动中的按钮点击

/**
         * Get Posts from Group
         * */
        btnGetPost.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                // getGroupPosts();
                //getGPosts();

                startActivity(new Intent(FBAppActivity.this, MessagesActivity.class));
            }
        });

当我点击按钮时出现此错误

10-28 01:48:28.585: E/AndroidRuntime(1299): FATAL EXCEPTION: main
10-28 01:48:28.585: E/AndroidRuntime(1299): java.lang.RuntimeException: Unable to start activity ComponentInfo{org.example.fbapp/org.example.fbapp.MessagesActivity}: java.lang.NullPointerException
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2306)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2358)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread.access$600(ActivityThread.java:156)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1340)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.os.Handler.dispatchMessage(Handler.java:99)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.os.Looper.loop(Looper.java:153)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread.main(ActivityThread.java:5297)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at java.lang.reflect.Method.invokeNative(Native Method)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at java.lang.reflect.Method.invoke(Method.java:511)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at dalvik.system.NativeStart.main(Native Method)
10-28 01:48:28.585: E/AndroidRuntime(1299): Caused by: java.lang.NullPointerException
10-28 01:48:28.585: E/AndroidRuntime(1299):     at org.example.fbapp.MessagesActivity.createAdapter(MessagesActivity.java:74)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at org.example.fbapp.MessagesActivity.onCreate(MessagesActivity.java:62)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.Activity.performCreate(Activity.java:5122)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1081)
10-28 01:48:28.585: E/AndroidRuntime(1299):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2270)
10-28 01:48:28.585: E/AndroidRuntime(1299):     ... 11 more

任何指针为什么??

【问题讨论】:

  • Caused by: java.lang.NullPointerException 10-28 01:48:28.585: E/AndroidRuntime(1299): at org.example.fbapp.MessagesActivity.createAdapter(MessagesActivity.java:74)第74行是哪一个?
  • 我对 Android 很陌生。请不要投反对票。
  • @Simon mAsyncRunner.request("203153109726651/feed", new RequestListener() {
  • mAsyncRunner 为空。我可以看到你在这里声明它,private AsyncFacebookRunner mAsyncRunner;,但我看不到你在哪里实例化它。我不知道如何使用该类,但是像mAsyncRunner = new AsyncFacebookRunner() BTW 这样的东西,我赞成,这足以弥补反对票。
  • Simon 是对的,你没有在使用之前初始化变量 mAsyncRunner,所以它是 null。

标签: android android-listview android-activity


【解决方案1】:

array_months 是在 onComplete 方法中异步加载的,但您没有等待它设置适配器。 array_months 尚未填写,因此您获得了 NPE。将您的适配器创建方法放在onComplete 方法下并在此之后填写列表。

【讨论】:

    猜你喜欢
    • 2014-02-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-09-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多