使用另一个包含Cursor的类的方法

时间:2012-08-08 19:01:17

标签: android cursor

为我的Android应用程序开发一个类,它将随机生成NPC及其统计数据。由于这些方法将在不同的活动中被调用,因此将它们放在自己的类中是最好的。然而,让它们包含的游标正常工作时遇到一些麻烦。

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;

    public class startscreen extends Activity {
        private dbhelper mydbhelper;
        Intent intent;


        /** Called when the activity is first created. */
            @Override
            public void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.startscreen);
                mydbhelper = dbhelper.getInstance(startscreen.this);
                }


            public void onClickNew(View v){
             intent = new Intent(getBaseContext(), newgame.class);
             startActivity(intent);
             }


            public void onClickLoad(View v){
             //intent = new Intent(getBaseContext(), mainmenu.class);
             //startActivity(intent);
                Generator obj = new Generator();
                obj.randomName();
             }

我将此底部按钮上的方法调用到主菜单以便于测试。

import java.util.Random;

import android.database.Cursor;
import android.util.Log;

public class Generator {
    public dbhelper mydbhelper;


    public String randomName(){
        Cursor name;
        Random nameRandom = new Random();
        int first = nameRandom.nextInt(171)+1;
        name = mydbhelper.getRandomName(first); //This is where I get the error. "NullPointerException"
        String firstName = name.getString(name.getColumnIndex(dbhelper.KEY_FIRST));
        int last = nameRandom.nextInt(245)+1;
        name =  mydbhelper.getRandomName(last);
        String lastName = name.getString(name.getColumnIndex(dbhelper.KEY_LAST));
        String fullName = firstName + " " + lastName;
        Log.e(fullName, "was the generated name");

        return fullName;

    }

}

如果我拿出游标并输入一个统计字符串来返回它就可以了。所以我错误地处理了这个游标。可悲的是,辛格尔顿和使用其他课程的方法是我的缺点,所以希望有人能够解释我做错了什么。

  public Cursor getRandomName(int number){
      return myDataBase.query(NAME_TABLE, new String[]{KEY_ID, KEY_FIRST, KEY_LAST},
              KEY_ID + " = " + number , null, null, null, KEY_ID);
    }

这是我正在使用的光标,位于我的dbhelper类中。

1 个答案:

答案 0 :(得分:2)

mydbhelper课程中的

Activitymydbhelper课程中的Generator不同。您需要在mydbhelper = dbhelper.getInstance()课程中致电Generator或在使用之前传递参考资料。

快速做到这一点的方法是:

public String randomName(dbhelper mydbhelp) {
  // code 
  name = mydbhelper.getRandomName(first);
  // code
  name.close
}

完成后,请记得关闭光标和数据库。首先关闭光标。