为我的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类中。
答案 0 :(得分:2)
mydbhelper
课程中的 Activity
与mydbhelper
课程中的Generator
不同。您需要在mydbhelper = dbhelper.getInstance()
课程中致电Generator
或在使用之前传递参考资料。
快速做到这一点的方法是:
public String randomName(dbhelper mydbhelp) {
// code
name = mydbhelper.getRandomName(first);
// code
name.close
}
完成后,请记得关闭光标和数据库。首先关闭光标。