android – 方法调用可能会产生java NullpointerException

我有一个代码
public String getNameUpdateEvent(long id) {
    Cursor mCursor =
            db.rawQuery("select name from events WHERE _id=" + id + ";",null);
    if (mCursor != null) {
        mCursor.movetoFirst();
    }
    String updateNameEvent;
    updateNameEvent = mCursor.getString(mCursor.getColumnIndex("name"));
    return updateNameEvent;
}

我得到一个警告

Warning:(173,45) Method invocation 'mCursor.getColumnIndex("name")' may produce 'java.lang.NullPointerException'

我可以修复它吗?

解决方法

你的光标不能为null,它将始终有任何值.但是光标可以是空的,所以你应该首先使用movetoFirst()方法去游标中的第一行,如果它返回true,这意味着该游标至少有一行,所以你可以用它来完成所有的操作,如果它返回false – 这意味着您的查询没有任何内容,因此您没有任何行可以获取数据.你的代码应该是这样的:
public String getNameUpdateEvent(long id) {
    Cursor mCursor =
        db.rawQuery("select name from events WHERE _id=" + id + ";",null);

    String updateNameEvent = null;
    if (mCursor != null && mCursor.movetoFirst()) {
        updateNameEvent = mCursor.getString(mCursor.getColumnIndex("name"));
    }
    return updateNameEvent;
}

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...