Android Android.database.CursorIndexOutOfBoundsException:请求索引x,大小为x
我试图用HighscoreDB中的数据填充10个文本视图。每次我的应用程序的游戏结束时,都会要求用户在数据库中存储他们的分数以及姓名。 然后,我填充10个文本视图(实际上是20个,但有10行有名称和分数)。这曾经是有效的(当HighscoreDB中有一些highscore记录时),但是自从我创建了一个新的模拟器并因此删除了所有highscore行之后,我一直得到 “android.database.CursorIndexOutOfBoundsException:请求索引x,大小为x”错误。 x表示我当前有多少行,例如,如果我在DB中有5个高分行,错误将是“请求索引5,大小为5”(通过尝试新方法解决问题发现了这一点,但问题仍然存在,我注意到索引也在增加)。 有人能指出我做错了什么,或者告诉我如何修复代码吗 这是我的HighScore活动中的代码,其中HighScore被放在文本视图中:Android Android.database.CursorIndexOutOfBoundsException:请求索引x,大小为x,android,sqlite,cursor,Android,Sqlite,Cursor,我试图用HighscoreDB中的数据填充10个文本视图。每次我的应用程序的游戏结束时,都会要求用户在数据库中存储他们的分数以及姓名。 然后,我填充10个文本视图(实际上是20个,但有10行有名称和分数)。这曾经是有效的(当HighscoreDB中有一些highscore记录时),但是自从我创建了一个新的模拟器并因此删除了所有highscore行之后,我一直得到 “android.database.CursorIndexOutOfBoundsException:请求索引x,大小为x”错误。 x表
db = (new HighscoreDB(this)).getWritableDatabase();
cursor = db.rawQuery("SELECT _id, name, score FROM highscore ORDER BY score DESC", null);
cursor.moveToFirst();
for (int i = 0; i < 10; i++) {
TableRow row = (TableRow)mHighscoreTable.getChildAt(i+1);
TextView tvName = (TextView)row.getChildAt(1);
tvName.setText(cursor.getString(1));
TextView tvScore = (TextView)row.getChildAt(2);
tvScore.setText(Integer.toString(cursor.getInt(2)));
cursor.moveToNext();
}
这是我最近的错误:
05-25 17:03:16.786: E/AndroidRuntime(780): FATAL EXCEPTION: main
05-25 17:03:16.786: E/AndroidRuntime(780): java.lang.RuntimeException: Unable to start activity ComponentInfo{be.michiel.test/be.michiel.test.HighscoreActivity}: android.database.CursorIndexOutOfBoundsException: Index 5 requested, with a size of 5
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.os.Handler.dispatchMessage(Handler.java:99)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.os.Looper.loop(Looper.java:123)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread.main(ActivityThread.java:3683)
05-25 17:03:16.786: E/AndroidRuntime(780): at java.lang.reflect.Method.invokeNative(Native Method)
05-25 17:03:16.786: E/AndroidRuntime(780): at java.lang.reflect.Method.invoke(Method.java:507)
05-25 17:03:16.786: E/AndroidRuntime(780): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
05-25 17:03:16.786: E/AndroidRuntime(780): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
05-25 17:03:16.786: E/AndroidRuntime(780): at dalvik.system.NativeStart.main(Native Method)
05-25 17:03:16.786: E/AndroidRuntime(780): Caused by: android.database.CursorIndexOutOfBoundsException: Index 5 requested, with a size of 5
05-25 17:03:16.786: E/AndroidRuntime(780): at android.database.AbstractCursor.checkPosition(AbstractCursor.java:580)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:214)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:41)
05-25 17:03:16.786: E/AndroidRuntime(780): at be.michiel.test.HighscoreActivity.onCreate(HighscoreActivity.java:79)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-25 17:03:16.786: E/AndroidRuntime(780): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
05-25 17:03:16.786: E/AndroidRuntime(780): ... 11 more
请帮我找出我的错误。我一直在寻找答案。
提前谢谢 出现错误是因为您试图访问不存在的第11个TableRow子项 替换
TableRow行=(TableRow)mHighscoreTable.getChildAt(i+1)代码>
与
TableRow行=(TableRow)mHighscoreTable.getChildAt(i)代码>
此外,由于将ID属性设置为“自动增量”,索引变得越来越大
代码的另一个问题是调用cursor.moveToNext();关于第10项。您可以修改“for”语句,使其如下所示:
for (int i = 0; i < 10 && !cursor.isAfterLast(); i++) {
for(int i=0;i<10&&!cursor.isAfterLast();i++){
如果不检查下一条记录是否可用,就不能执行此操作。请尝试按以下方式更改代码:
db = (new HighscoreDB(this)).getWritableDatabase();
cur = db.rawQuery("SELECT _id, name, score FROM highscore ORDER BY score DESC", null);
int noOfScorer=0;
cur.moveToFirst();
while ((!cur.isAfterLast())&&noOfScorer<11)
{
noOfScorer++;
TableRow row = (TableRow)mHighscoreTable.getChildAt(noOfScorer);
TextView tvName = (TextView)row.getChildAt(1);
TextView tvScore = (TextView)row.getChildAt(2);
tvName.setText(cur.getString(1));
tvScore.setText(Integer.toString(cur.getInt(2)));
cur.moveToNext();
}
db=(新的HighscoreDB(this)).getWritableDatabase();
cur=db.rawQuery(“按分数描述从高分顺序中选择_id、名称、分数”,null);
int noOfScorer=0;
cur.moveToFirst();
(!cur.isAfterLast())和&noOfScorerI尝试此操作时,在“TextView tvName=(TextView)row.getChildAt(1);”行上出现错误“java.lang.NullPointerException”.我认为这与我之前的代码行是在1开始的有关,现在是在0开始的我相信很棒!!很高兴它帮助了你,如果它对你有用,你应该接受答案,这样其他人也可以利用它。
db = (new HighscoreDB(this)).getWritableDatabase();
cur = db.rawQuery("SELECT _id, name, score FROM highscore ORDER BY score DESC", null);
int noOfScorer=0;
cur.moveToFirst();
while ((!cur.isAfterLast())&&noOfScorer<11)
{
noOfScorer++;
TableRow row = (TableRow)mHighscoreTable.getChildAt(noOfScorer);
TextView tvName = (TextView)row.getChildAt(1);
TextView tvScore = (TextView)row.getChildAt(2);
tvName.setText(cur.getString(1));
tvScore.setText(Integer.toString(cur.getInt(2)));
cur.moveToNext();
}