- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
基本上我有一个方法可以从我的数据库中填充 ListView 。
我在游标上收到空指针和“无法停止 Activity ”错误。
这就是我返回光标的方式:
public Cursor getAppointmentsData() {
String[] columns = new String[] { KEY_ROWAPPID, KEY_NAMEAPP,
KEY_TYPEAPP, KEY_TIMEAPP, KEY_DATEAPP, KEY_COMMENTAPP };
Cursor c = ourDatabase.query(DATABASE_TABLEAPP, columns, null, null,
null, null, KEY_NAMEAPP + " ASC", null);
if (c != null) {
if (c.getCount() > 0 && c.moveToFirst())
{
c.moveToFirst();
return c;
}
}
c.close();
return null;
}
当数据库为空时,即没有数据,它会崩溃......如果有数据就没问题。这让我相信我从我的光标返回了一个空值。
你们能看出这种返回光标的方法有问题吗?
很抱歉这个简单的问题,但在我拆开代码之前我想我会在这里问。
新编辑:
公共(public)游标 getAppointmentsData() { String[] columns = new String[] { KEY_ROWAPPID, KEY_NAMEAPP, KEY_TYPEAPP, KEY_TIMEAPP, KEY_DATEAPP, KEY_COMMENTAPP }; 游标 c = ourDatabase.query(DATABASE_TABLEAPP, columns, null, null, null, null, KEY_NAMEAPP + "ASC", null);
if (c != null) {
c.moveToFirst();
}
c.close();
return c;
}
最佳答案
你应该能够做到以下几点
if (c.moveToFirst()){
return c;
}
原因是 query()
方法不会返回 null。它只会返回一个空游标。所以,没有必要检查它是否为空。此外,如果 moveToFirst()
无法移动到第一行(因此,如果游标为空),则计算结果为 false。因此,计数检查是多余的。
但是,您确定从您的方法中返回 null 是安全的吗?如果没有结果,您将明确返回 null。此外,您是否知道返回后永远不会调用 close()
方法(以防您有带结果的游标)。
我不完全知道你用你的方法返回光标做了什么,但我建议你简单地返回它。但我怀疑你想要的只是
public Cursor getAppointmentsData() {
String[] columns = new String[] { KEY_ROWAPPID, KEY_NAMEAPP,
KEY_TYPEAPP, KEY_TIMEAPP, KEY_DATEAPP, KEY_COMMENTAPP };
return ourDatabase.query(DATABASE_TABLEAPP, columns, null, null,
null, null, KEY_NAMEAPP + " ASC", null);
}
更新 - 关于何时关闭游标
如果您在返回游标之前关闭游标,则方法 getAppointmentsData()
将返回一个关闭的游标。我很确定这不是你想要的。因为在这个阶段,您还没有完成游标,所以现在自己清理还为时过早:)
你要的是这样的东西。首先,使用我上面建议的方法 getAppointmentsData()
,它不会关闭游标,它只是返回它。现在像这样构建你的光标适配器
public CursorAdapter myCursorAdapter;
@Override
public void onCreate(Bundle savedInstanceState) {
//... all your stuff
myCursorAdapter = new CursorAdapter(this, getAppointmentsData());
}
现在,将游标适配器传递给您的 ListView,在这个阶段,ListView 可以使用底层游标(因为它仍然存在,没有关闭 :P)。然后,当您确定您的应用程序不再需要光标时,关闭它。我建议在您的 Activity 被销毁时执行此操作
@Override
public void onDestroy() {
myCursorAdapter.getCursor().close();
}
关于java - 我是在问这个返回的游标的问题吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15399321/
我有这个gradle命令行,可以完美地工作: /gradle app:testalldevicesproductionenv -Pandroid.testInstrumentationRunnerAr
因此,我使用 NativeBase 作为组件框架来开发 React Native 应用程序。 我正在使用卡片组件。 这是我的代码: render(){ return(
假设我有这样的Kotlin代码: val var1:String? = isVar1Present() val var2:String? = isVar2Present() val var3:Stri
我想要一些有关当前正在使用的程序的指导,如果用户两次输入相同的值,我已经成功创建了一对整数并处理了异常。我一直坚持执行创建对的相同过程,但不是整数,它必须是字符串。 我的一个建议是更改有序对的随机生成
我的 node.js e2e 测试有问题。我想等待 2 个 promise 解决。但由于某种原因,当我使用 Q.all 时,它只是卡住了我的应用程序。我正在使用 kriskowal 的 Q 1.0.0
实际上我已经开发了使用 Hdfs 存储图像的应用程序。现在我想迁移服务器并在新服务器中再次设置 hadoop。我如何将 HDFS(旧服务器)中的图像文件备份到新服务器中的 HDFS? 我尝试使用 Co
我想在GCP上建立一个完全自动化的CI / CD管道。在Cloud Build中,我已经有了一个cloudbuild.yaml,它可以构建Dockerfile并将构建的Docker镜像推送到Conta
我刚刚开始使用Docker,并能够使用Ubuntu 14.03 / LXDE / VNC设置Docker镜像,由于我可以从外部连接到VNC服务器,因此可以很好地工作。 现在,我试图理解Docker的网
我有 Talend Studio Data Intergration 6.2.1。作业导出为 .war,作为 Web 服务在服务器上执行。 我的问题是,有什么方法可以找出哪个应用程序调用我的 ws?
这个问题在这里已经有了答案: Why is super.super.method(); not allowed in Java? (22 个答案) 关闭 9 年前。 我怀疑我想做的事情是否可行。我有
我似乎无法找到正确的方式来表达这一点以进行 Google 搜索。 当我使用 q.all 并且只有一两个失败时(在 Node.js 中)会发生什么。我需要为我使用 Promise 的所有成功实例输入 .
Closed. This question needs to be more focused. It is not currently accepting answers. Learn more。 想
我已经整理了一个宏,它允许我将数据从一张表存档到另一张表,但是我无法让它在之后清除信息。第一列包含我不想清除的数字,现在它只是清除 B 列中的数据。 如果有人可以看看这个,我会非常感激。 'Sub a
我有一个 C# 程序可以从 .txt 文件创建 Excel 文件报告。 它工作完美,但有时(经常)当我打开一个电子表格时,Excel 会打开 2 个电子表格: 1 我保存的文件。1 有一些名为“Pla
为什么不玩 onclick="catch()"?我不明白。 function catch () { alert("safsf"); } ... 最佳答案 catch 是
在 Q 中,有哪些方法可以在 where 子句中使用嵌套查询的结果? 我正在寻找类似于 SQL 语句的内容。 select from food where type_id in ( selec
虽然这段代码可以工作: var promise = function(val) { var _val = val; return setTimeout(function(_val) {
自Mozilla和Google宣布,他们打算将来使用默认设置通过HTTPS激活DNS,并且IETF正式批准了该草案(https://datatracker.ietf.org/wg/doh/about/
OnClickListener 无法与 ScrollView 一起使用,因为“扩展了 Fragment”。我该如何使用它呢?一个例子就足够了。谢谢.. 更新Fragment1.java package
char name[20]=""; char address [50]= ""; do{ printf("Input your name [1..20] : "); scanf("%s
我是一名优秀的程序员,十分优秀!