游标生命周期问题

时间:2013-02-01 21:41:32

标签: java android

我正在尝试解决我一直在与其进行斗争的'敲定'错误。在我尝试了许多不同的数据库和cursor'.close()'方法之后,这个问题仍然存在。

显示的代码是现在的样子。如果有人可以指导我以正确的方式关闭我的光标和数据库,那将是很好的,因为如果我关闭一个,它似乎与另一个冲突!

目前,我正在尝试使用从对话框列表的Intent中调用的“AddAppointmentContact”类的“onCreate”方法中的对象方法集中设置检索到的字符串值来设置“EditText”。

目前我收到此错误:

错误:

02-01 21:23:18.947: E/Cursor(274): Finalizing a Cursor that has not been deactivated or closed. database = /data/data/com.example.flybase2/databases/persons_name, table = contactsTable, query = SELECT _id, persons_name, persons_telephone, persons_email, persons_comments FROM contactsTable WHER

我在我的代码中运行类似的代码,这样可以正常工作。

这是与我保存对话框的列表视图中选择的名称ID捆绑在一起的代码:

else if (items[item].equals("Add Appointment")) {

Intent conAdd = new Intent("com.example.flybase2.AddAppointmentContact");
conAdd.putExtra("newpassedID", idToPass);
startActivity(conAdd);

打开的“AddAppointmentContact”类:

Bundle extras = getIntent().getExtras(); 
    sentID = extras.getLong("newPassedID"); 


    DBHandlerApp NameAppointPass = new DBHandlerApp(this, null, null);

    NameAppointPass.open();
    String nameReturned = NameAppointPass.getName(sentID);

    setName = (EditText) findViewById(R.id.inputAppName);
    setName.setText(nameReturned);

'.getName()'方法:

public String getName(long passedID) {

String [] columns = new String[]{KEY_ROWAPPID, KEY_NAMEAPP,   KEY_TYPEAPP, KEY_TIMEAPP, KEY_DATEAPP, KEY_COMMENTAPP};
        Cursor c = ourDatabase.query(DATABASE_TABLEAPP, columns, KEY_ROWAPPID + "=" + passedID, null, null, null, null);

        if(c != null && c.getCount() > 0)
        {
        c.moveToFirst();
        String name = c.getString(1);

        return name;
        }

        return null;

2 个答案:

答案 0 :(得分:0)

您需要关闭光标。

返回name之前

c.close()或null。

答案 1 :(得分:0)

同意您必须关闭Cursor。试试这个:

    if(c != null) {
        if(c.getCount() > 0 && c.moveToFirst())
        {
            String name = c.getString(1);
            c.close();
            return name;
        }
        c.close();
    }
    return null;