首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这个方法中是什么导致了“强制关闭”?

这个方法中是什么导致了“强制关闭”?
EN

Stack Overflow用户
提问于 2011-03-17 01:17:33
回答 1查看 119关注 0票数 0

我需要从数据库表中删除一行,然后将下面的行移到上面。

代码语言:javascript
复制
public void updateDraftsAfterDelete(long rowId)
{
        String txt="",rid="",sto="",est="",sin="";
        boolean b=true;
        Cursor cursor = db.query(DATABASE_DRAFTS_TABLE, new String[] {
                KEY_DRAFTS_ROWID,
                KEY_DRAFTS_SENDTO,
                KEY_DRAFTS_TXT,
                KEY_DRAFTS_ENCST,
                KEY_DRAFTS_SIN }, 
          null, null, null, null, null);

    cursor.moveToPosition((int)(rowId+1));

    ContentValues values = new ContentValues();

    for(int i=(int)rowId;i<cursor.getCount();i++)
    {
        rid=new String(""+((Integer.parseInt(cursor.getString(0)))-1));
        sto=cursor.getString(1);
        txt=cursor.getString(2);
        est=cursor.getString(3);
        sin=cursor.getString(4);

    values.put(KEY_DRAFTS_SENDTO,sto);
        values.put(KEY_DRAFTS_TXT,txt);
        values.put(KEY_DRAFTS_ENCST, est);
        values.put(KEY_DRAFTS_SIN, sin);


        b=db.update(DATABASE_DRAFTS_TABLE, values, 
                KEY_DRAFTS_ROWID + "=" + rid, null) > 0;

        cursor.moveToNext();
    }
    cursor.moveToLast();

    rid=cursor.getString(0);

    Toast.makeText(null, rid, Toast.LENGTH_LONG).show();

        b=db.delete(DATABASE_DRAFTS_TABLE, KEY_DRAFTS_ROWID + "=" + rid, null) >0;
}

在运行它时,它会正确地替换行,但不会删除最后一行。有什么问题吗?谢谢。

EN

回答 1

Stack Overflow用户

发布于 2011-04-03 19:49:08

您需要将上下文对象传递给对Toast.makeText的调用,您不能传递null,这将抛出NullPointerException并强制关闭。

更改线路

代码语言:javascript
复制
Toast.makeText(null, rid, Toast.LENGTH_LONG).show();

至:

代码语言:javascript
复制
Context context = getApplicationContext();
Toast.makeText(context, rid, Toast.LENGTH_LONG).show();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5329090

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档