为什么LogCat显示IllegalStateException?

时间:2015-01-20 20:00:05

标签: android eclipse logging

我发现了一个奇怪的崩溃错误。我定义了一个Alert对话框,其上下文我使用getListView()。getContext()获得。但是logcat显示了IllegalStateException。这可能是因为当我在findInBackGround()方法被激活之前关闭活动时,它将没有上下文,因为活动被终止并且方法findInBackGround()在后台执行并且仍将在后台执行。 java代码片段是

public class InboxFragment extends ListFragment {
protected List<ParseObject> myMessages;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {
    View rootView = inflater.inflate(R.layout.fragment_inbox, container,
            false);
    return rootView;
}

@Override
public void onListItemClick(ListView l, View v, int position, long id) {
    super.onListItemClick(l, v, position, id);

    String fileType = myMessages.get(position).getString(
            ParseConstants.KEY_FILETYPE);
    ParseFile file = myMessages.get(position).getParseFile(
            ParseConstants.KEY_FILE);
    Uri uri = Uri.parse(file.getUrl());
    if (fileType.equals(R.string.filetype_image)) {
        Intent i = new Intent(getActivity(), ViewImageActivity.class);
        i.setData(uri);
        startActivity(i);
    } else {
        Intent i = new Intent();
        i.setData(uri);
        i.setType("video/*");
        startActivity(i);

    }
    List<String> count = myMessages.get(position).getList(
            ParseConstants.KEY_RECEPIENTSIDS);
    if (count.size() == 1) {
        myMessages.get(position).deleteInBackground();
    } else {
        myMessages.get(position).getList(ParseConstants.KEY_RECEPIENTSIDS)
                .remove(ParseUser.getCurrentUser().getObjectId());
        myMessages.get(position).saveInBackground();

    }

}

private boolean isNetworkAvailableAndConnected() {

    ConnectivityManager manager = (ConnectivityManager) getActivity().getSystemService(Context.CONNECTIVITY_SERVICE);
    NetworkInfo info = manager.getActiveNetworkInfo();
    if (info != null && info.isConnected())
        return true;
    else
        return false;
}

@Override
public void onResume() {
    super.onResume();
    if (isNetworkAvailableAndConnected()) {
        ParseQuery<ParseObject> query = new ParseQuery<ParseObject>(
                ParseConstants.KEY_MESSAGES);
        query.whereEqualTo(ParseConstants.KEY_RECEPIENTSIDS, ParseUser
                .getCurrentUser().getObjectId());
        query.orderByDescending("createdAt");
        query.findInBackground(new FindCallback<ParseObject>() {

            @Override
            public void done(List<ParseObject> messages, ParseException e) {
                if (e == null) {
                    // found messages successfully
                    myMessages = messages;
                    String[] usernames = new String[myMessages.size()];

                    for (int i = 0; i < messages.size(); i++) {
                        usernames[i] = messages.get(i).getString(
                                ParseConstants.KEY_SENDERNAME);

                    }
                    if (getListView().getAdapter() == null) {
                        MessageAdapter adapter = new MessageAdapter(
                                getListView().getContext(), myMessages);
                        setListAdapter(adapter);
                    } else {
                        // refill
                        ((MessageAdapter) getListView().getAdapter())
                                .refill(myMessages);

                    }

                } else {
                    AlertDialog.Builder builder = new AlertDialog.Builder(
                            getListView().getContext());
                    builder.setMessage(R.string.messages_loading_failed);
                    builder.setTitle(getString(R.string.dialog_title));
                    builder.setPositiveButton(android.R.string.ok, null);
                    AlertDialog dialog = builder.create();
                    dialog.show();

                }

            }
        });

    } else {
        Toast.makeText(getActivity(), "No internet connection",
                Toast.LENGTH_LONG).show();
    }
}

} logcat是

02-08 00:06:22.444: E/AndroidRuntime(26541): FATAL EXCEPTION: main

02-08 00:06:22.444:E / AndroidRuntime(26541):java.lang.IllegalStateException:尚未创建内容视图 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.app.ListFragment.ensureList(ListFragment.java:386) 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.app.ListFragment.getListView(ListFragment.java:280) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.example.friendsapp.InboxFragment $ 1.done(InboxFragment.java:116) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.parse.FindCallback.internalDone(FindCallback.java:45) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.parse.FindCallback.internalDone(FindCallback.java:31) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.parse.Parse $ 4 $ 1.run(Parse.java:792) 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.os.Handler.handleCallback(Handler.java:800) 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.os.Handler.dispatchMessage(Handler.java:100) 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.os.Looper.loop(Looper.java:194) 02-08 00:06:22.444:E / AndroidRuntime(26541):在android.app.ActivityThread.main(ActivityThread.java:5371) 02-08 00:06:22.444:E / AndroidRuntime(26541):at java.lang.reflect.Method.invokeNative(Native Method) 02-08 00:06:22.444:E / AndroidRuntime(26541):at java.lang.reflect.Method.invoke(Method.java:525) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:833) 02-08 00:06:22.444:E / AndroidRuntime(26541):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 02-08 00:06:22.444:E / AndroidRuntime(26541):at dalvik.system.NativeStart.main(Native Method)

有没有办法完成findInBackgound完成的工作而不会导致崩溃。或者由于任何其他逻辑错误导致崩溃。

2 个答案:

答案 0 :(得分:1)

确保从DDMS窗口中选择设备,并选择了“所有消息”或要在“保存的过滤器”部分中显示的衍生物。如果您不想过滤掉任何内容,请不要在上面的搜索字段中输入任何内容。拔出并重新插入设备往往可以解决问题。

如果这是第一次,那么您需要通过在设置中打开USB调试来允许与您的设备进行通信。首先打开您可以研究的开发人员选项即可完成此任务。

答案 1 :(得分:1)

我从博客中找到了答案。我需要使用

if(getActivity() != null ) 

在显示对话框之前。谢谢大家。