JAVA关于在函数内的局部变量的生命周期,及返回值问题

       

sql = String.format("SELECT mMax FROM ItemParas WHERE sampleType  ='%s' and name ='%s',
                softType, item");
Cursor c = null;
c = db.rawQuery(sql, null);
if (c.moveToNext()) {
   String max = c.getString(c.getColumnIndex("mMax"));
   c.close();
   return max;
} else {
   return "/";//2020/4/2 从返回“-”改为“/”,为了适应后面对“-”的分割,不出错
}

以上为源代码,原意是为了找出一个项目对应的最大值。前提,数据库查找没有问题,安卓版本为4.0.3,jdk为1.8.

 String max = c.getString(c.getColumnIndex("mMax"));

原本debug已经进去了c.close();max 的值也是找到了,而下一步的应该是到 return max;但事实上,他竟然跳转到了 return "/", 

??黑人问号脸,在跳转到一个分支之后还跳转到另一个分支,然后给我返回了 " /" 。老实说,我现在都没理清楚这是为啥,也就大概从生命周期上来解释了(没错,就是第六感)。因为是之前进来说是qt,暗里就让我做android,可能问题对其他人很小,但在我这里以后可能会是必发的bug。先记录一下

 

修改过后,在if 分支外先定义,嗯。。。完美解决(一脸懵逼)

 

String max = "";

sql = String.format("SELECT mMax FROM ItemParas WHERE sampleType  ='%s' and name ='%s',
                softType, item");
        Cursor c = null;
        c = db.rawQuery(sql, null);
        if (c.moveToNext()) {
            max = c.getString(c.getColumnIndex("mMax"));
            c.close();
            return max;
        } else {
            return "/";//2020/4/2 从返回“-”改为“/”,为了适应后面对“-”的分割,不出错
        }

 String max = "";

max = c.getString(c.getColumnIndex("mMax"));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值