IllegalStateException异常:获得现场插槽从第0山坳-1失败 [英] IllegalStateException: get field slot from row 0 col -1 failed

查看:117
本文介绍了IllegalStateException异常:获得现场插槽从第0山坳-1失败的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

下面是我的LogCat中:

  01-15 22:13:08.277:ERROR / AndroidRuntime(28747):java.lang.IllegalStateException:从第0山坳得到现场插槽-1失败
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.database.CursorWindow.getLong_native(本机方法)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.database.CursorWindow.getLong(CursorWindow.java:414)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.database.AbstractWindowedCursor.getLong(AbstractWindowedCursor.java:108)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.database.CursorWrapper.getLong(CursorWrapper.java:127)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter.java:60)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.CursorAdapter.getView(CursorAdapter.java:186)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.AbsListView.obtainView(AbsListView.java:2818)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.ListView.measureHeightOfChildren(ListView.java:1218)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.ListView.onMeasure(ListView.java:1131)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.View.measure(View.java:8039)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.RelativeLayout.measureChild(RelativeLayout.java:554)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.RelativeLayout.onMeasure(RelativeLayout.java:377)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.View.measure(View.java:8039)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.View.measure(View.java:8039)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.LinearLayout.measureVertical(LinearLayout.java:464)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.LinearLayout.onMeasure(LinearLayout.java:278)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.View.measure(View.java:8039)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.View.measure(View.java:8039)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.ViewRoot.performTraversals(ViewRoot.java:779)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.view.ViewRoot.handleMessage(ViewRoot.java:1658)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.os.Handler.dispatchMessage(Handler.java:99)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.os.Looper.loop(Looper.java:123)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在android.app.ActivityThread.main(ActivityThread.java:4363)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在java.lang.reflect.Method.invokeNative(本机方法)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在java.lang.reflect.Method.invoke(Method.java:521)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:862)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在dalvik.system.NativeStart.main(本机方法)
 

在LogCat中是指这条线code 01-15 22:13:08.277:ERROR / AndroidRuntime(28747):在com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter的.java:60)。这是我的任务适配器的 bindView 方法:

  @覆盖
公共无效bindView(查看视图,上下文的背景下,光标光标){
    复选框复选框=(复选框)view.findViewById(R.id.completed);
    TextView的DUE_DATE =(TextView中)view.findViewById(R.id.due_date);

    字符串标题= cursor.getString(cursor.getColumnIndex(Tasks.TITLE));
    布尔完成= Util.intToBool(cursor.getInt(cursor.getColumnIndex(Tasks.COMPLETED)));

    SimpleDateFormat的格式=新的SimpleDateFormat(EEEEEE,MMM DD YYYY HH:MM AA);
    长unixTime = Calendar.getInstance()getTimeInMillis()。
    如果(cursor.getLong(cursor.getColumnIndex(Tasks.DUE_DATE))大于0){
        Log.v(TasksAdapter,Unix时间是+ unixTime);
        unixTime = cursor.getLong(cursor.getColumnIndex(Tasks.DUE_DATE));
        日历由于= Util.timestampToDate(unixTime);

        due_date.setText(format.format(due.getTime()));
    }
    checkbox.setText(职称);
    checkbox.setChecked(已完成);
    due_date.setText(无截止日期);
}
 

我已经验证该列确实存在100%。可能是什么问题?

更新:
光标是从bindView方法,所以我还没有创建的查询游标自己。我重新创建数据库,现在我得到这个错误:

  9月一号至16号:46:39.459:ERROR / AndroidRuntime(32563):java.lang.IllegalArgumentException:如果列'DUE_DATE不存在
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:314)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.java:99)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter.java:64)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.CursorAdapter.getView(CursorAdapter.java:186)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.AbsListView.obtainView(AbsListView.java:2818)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.ListView.measureHeightOfChildren(ListView.java:1218)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.ListView.onMeasure(ListView.java:1131)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.View.measure(View.java:8039)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.RelativeLayout.measureChild(RelativeLayout.java:554)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.RelativeLayout.onMeasure(RelativeLayout.java:377)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.View.measure(View.java:8039)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.View.measure(View.java:8039)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.LinearLayout.measureVertical(LinearLayout.java:464)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.LinearLayout.onMeasure(LinearLayout.java:278)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.View.measure(View.java:8039)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.View.measure(View.java:8039)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.ViewRoot.performTraversals(ViewRoot.java:779)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.view.ViewRoot.handleMessage(ViewRoot.java:1658)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.os.Handler.dispatchMessage(Handler.java:99)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.os.Looper.loop(Looper.java:123)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在android.app.ActivityThread.main(ActivityThread.java:4363)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在java.lang.reflect.Method.invokeNative(本机方法)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在java.lang.reflect.Method.invoke(Method.java:521)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:862)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
九月一日至16号:46:39.459:ERROR / AndroidRuntime(32563):在dalvik.system.NativeStart.main(本机方法)
 

我已经验证列索引-1:

  9月一号至16号:46:39.434:VERBOSE / TasksAdapter(32563):该指数为-1
 

和该DUE_DATE列存在:

  9月一号至16号:46:29.839:VERBOSE / TasksProvider(32563):创建数据库...
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):_id
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):标题
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):已完成
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):DUE_DATE
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):注意事项
九月一日至16号:46:29.839:VERBOSE / TasksProvider(32563):重要
 

解决方案

确保生成光标查询包括Tasks.DUE_DATE指现场。如果没有,getColumnIndex将返回-1。您也可以使用getColumnIndexOrThrow,它可以让你赶上一个IllegalArgumentException。

Here is my LogCat:

01-15 22:13:08.277: ERROR/AndroidRuntime(28747): java.lang.IllegalStateException: get field slot from row 0 col -1 failed
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.database.CursorWindow.getLong_native(Native Method)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.database.CursorWindow.getLong(CursorWindow.java:414)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.database.AbstractWindowedCursor.getLong(AbstractWindowedCursor.java:108)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.database.CursorWrapper.getLong(CursorWrapper.java:127)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter.java:60)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.CursorAdapter.getView(CursorAdapter.java:186)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.AbsListView.obtainView(AbsListView.java:2818)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.ListView.measureHeightOfChildren(ListView.java:1218)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.ListView.onMeasure(ListView.java:1131)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.View.measure(View.java:8039)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.RelativeLayout.measureChild(RelativeLayout.java:554)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:377)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.View.measure(View.java:8039)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.View.measure(View.java:8039)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:464)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.LinearLayout.onMeasure(LinearLayout.java:278)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.View.measure(View.java:8039)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.View.measure(View.java:8039)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.ViewRoot.performTraversals(ViewRoot.java:779)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1658)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.os.Looper.loop(Looper.java:123)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at android.app.ActivityThread.main(ActivityThread.java:4363)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at java.lang.reflect.Method.invokeNative(Native Method)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at java.lang.reflect.Method.invoke(Method.java:521)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
01-15 22:13:08.277: ERROR/AndroidRuntime(28747):     at dalvik.system.NativeStart.main(Native Method)

The LogCat refers to this line of code01-15 22:13:08.277: ERROR/AndroidRuntime(28747): at com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter.java:60). Here is my task adapter's bindView method:

@Override
public void bindView(View view, Context context, Cursor cursor) {
    CheckBox checkbox = (CheckBox)view.findViewById(R.id.completed);
    TextView due_date = (TextView)view.findViewById(R.id.due_date);

    String title = cursor.getString(cursor.getColumnIndex(Tasks.TITLE));
    boolean completed = Util.intToBool(cursor.getInt(cursor.getColumnIndex(Tasks.COMPLETED)));

    SimpleDateFormat format = new SimpleDateFormat("EEEEEE, MMM dd yyyy hh:mm aa");
    long unixTime = Calendar.getInstance().getTimeInMillis();
    if (cursor.getLong(cursor.getColumnIndex(Tasks.DUE_DATE)) > 0) {
        Log.v("TasksAdapter", "Unix time is " + unixTime);
        unixTime = cursor.getLong(cursor.getColumnIndex(Tasks.DUE_DATE));
        Calendar due = Util.timestampToDate(unixTime);

        due_date.setText(format.format(due.getTime()));
    }
    checkbox.setText(title);
    checkbox.setChecked(completed);
    due_date.setText("No Deadline");
}

I have verified 100% that the column does exist. What could be the problem?

UPDATE:
The cursor is from a bindView method, so I have not created the query for the cursor myself. I recreated the database and now I get this error:

01-16 09:46:39.459: ERROR/AndroidRuntime(32563): java.lang.IllegalArgumentException: column 'due_date' does not exist
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:314)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.java:99)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at com.mohit.geo2do.adapters.TasksAdapter.bindView(TasksAdapter.java:64)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.CursorAdapter.getView(CursorAdapter.java:186)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.AbsListView.obtainView(AbsListView.java:2818)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.ListView.measureHeightOfChildren(ListView.java:1218)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.ListView.onMeasure(ListView.java:1131)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.View.measure(View.java:8039)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.RelativeLayout.measureChild(RelativeLayout.java:554)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:377)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.View.measure(View.java:8039)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.View.measure(View.java:8039)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:464)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.LinearLayout.onMeasure(LinearLayout.java:278)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.View.measure(View.java:8039)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3025)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.View.measure(View.java:8039)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.ViewRoot.performTraversals(ViewRoot.java:779)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1658)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.os.Looper.loop(Looper.java:123)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at android.app.ActivityThread.main(ActivityThread.java:4363)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at java.lang.reflect.Method.invokeNative(Native Method)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at java.lang.reflect.Method.invoke(Method.java:521)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at  com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
01-16 09:46:39.459: ERROR/AndroidRuntime(32563):     at dalvik.system.NativeStart.main(Native Method)

I have verified that the column index is -1:

01-16 09:46:39.434: VERBOSE/TasksAdapter(32563): The index is -1

And that the due_date column exists:

01-16 09:46:29.839: VERBOSE/TasksProvider(32563): Creating database...
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): _id
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): title
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): completed
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): due_date
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): notes
01-16 09:46:29.839: VERBOSE/TasksProvider(32563): importance

解决方案

Ensure that the query that generated your Cursor includes the field which Tasks.DUE_DATE refers to. If it does not, getColumnIndex will return -1. You can also use getColumnIndexOrThrow, which allows you to catch an IllegalArgumentException.

这篇关于IllegalStateException异常:获得现场插槽从第0山坳-1失败的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆