0

正在为我的 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 类中。

4

1 回答 1

2

mydbhelper在您的班级中与您Activity班级中的参考不同。在使用它之前,您需要调用您的类或传递参考。mydbhelperGeneratormydbhelper = dbhelper.getInstance()Generator

一个快速的方法是:

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

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

于 2012-08-08T19:14:06.117 回答