cursoroutofbound error,request index=1,while size=-1

程序运行时出现以下错误提示:
10-30 09:00:35.077: E/AndroidRuntime(9930): android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1

造成出现该错误的代码如下:

	cursor = db.SelectDB(sql, new String[] { Integer.toString(id) }); // 
	if (cursor.getInt(cursor.getColumnIndex(DbTableColumName.isEnable)) == 1)
		{
			/* 保存状态 */
			inputName = cursor.getString(cursor
					.getColumnIndex(DbTableColumName.name));
			machineStatus.setInputType(inputName);

			/* 发送切换后组号发到高清板 */
			list.add((byte) i);
			commandPack.inputCtrCommandPack(Constant.HIFIADDR, (byte) 0xE0,
					list);
			/* 发送到OSD上显示 */
			listOsdSrc.add(inputName);
			osdDisplayInfo(listOsdSrc);
			break;
		}

造成该错误的原因:

 对数据的查询结果cursor进行操作时,必须要先执行cursor.moveToFirst(),却表cursor位于第一个数据行。正确的代码如下:

<span style="white-space:pre">		</span>cursor = db.SelectDB(sql, new String[] { Integer.toString(id) }); // 
		if (cursor.moveToFirst())
		{
			if (cursor.getInt(cursor.getColumnIndex(DbTableColumName.isEnable)) == 1)
			{
				/* 保存状态 */
				inputName = cursor.getString(cursor
						.getColumnIndex(DbTableColumName.name));
				machineStatus.setInputType(inputName);

				/* 发送切换后组号发到高清板 */
				list.add((byte) i);
				commandPack.inputCtrCommandPack(Constant.HIFIADDR, (byte) 0xE0,
						list);
				/* 发送到OSD上显示 */
				listOsdSrc.add(inputName);
				osdDisplayInfo(listOsdSrc);
				break;
			}
		}


10-30 09:00:35.077: E/AndroidRuntime(9930): android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值