Android 通过NullPointerException创建SQLiteDatabase
例外是Android 通过NullPointerException创建SQLiteDatabase,android,sqlite,android-sqlite,Android,Sqlite,Android Sqlite,例外是 public class DatabaseHundler { Context context; private static DatabaseHundler instance; private static helper help; public DatabaseHundler(Context context) { this.context = context; } public static DatabaseHundl
public class DatabaseHundler {
Context context;
private static DatabaseHundler instance;
private static helper help;
public DatabaseHundler(Context context) {
this.context = context;
}
public static DatabaseHundler getInstance(Context context)
{
if(instance == null)
{
instance = new DatabaseHundler(context);
}
if(help == null)
{
help = instance.new helper();
}
return instance;
}
private synchronized static SQLiteDatabase open()
{
try{
return help.getWritableDatabase();
/*switch(mode) {
case WRITE_MODE:
return db.getWritableDatabase();
case READ_MODE:
return db.getReadableDatabase();
default:
return db.getWritableDatabase();
}*/
}catch (Exception e) {
return null;
}
}
private class helper extends SQLiteOpenHelper
{
public helper() {
super(context, Constants.Database_Name, null, Integer.parseInt(Constants.Database_Version));
// TODO Auto-generated constructor stub
}
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
}
}
public boolean CreateTableMyData(String query)
{
SQLiteDatabase db = DatabaseHundler.open();
if(db != null)
{
db.execSQL(query);
}
return false;
}
public Cursor GetUserData(String tableName)
{
SQLiteDatabase db = DatabaseHundler.open();
if(db != null)
{
Cursor cursor = db.query(tableName, null, null, null, null, null, null);
try{
if(cursor != null)
{
if(cursor.getCount() >0)
{
return cursor;
}
}
}catch(Exception e){
}
}
return null;
}
public Cursor GetData(String tablename ,String colname , String val)
{
SQLiteDatabase db = DatabaseHundler.open();
if(db != null)
{
String query = "Select * from "+tablename+" where "+colname+" =? ";
Cursor cursor = db.rawQuery(query, new String[]{ val});
//Cursor cursor = db.query(tablename, null, null, null, null, null, null);
try{
if(cursor != null)
{
if(cursor.getCount() >0)
{
return cursor;
}
}
}catch(Exception e){
}
}
return null;
}
public boolean SaveUserData(ContentValues values , String tablename)
{
SQLiteDatabase dataBase = DatabaseHundler.open();
try{
if(dataBase != null)
{
if (values!= null)
{
dataBase.insertWithOnConflict(tablename, BaseColumns._ID, values, SQLiteDatabase.CONFLICT_REPLACE);
}
return true;
}
}catch(Exception e){}
return false;
}
public boolean DeleteData(String tablename)
{
SQLiteDatabase database = DatabaseHundler.open();
try{
if(database != null)
{
database.delete(tablename, null, null);
}
}catch(Exception e)
{
}
return false;
}
}
////////////////我们在其中创建数据库hundler的控制器类
public class Splash extends Activity
{
static String DeviceId;
static String Key;
static String Email;
static String Version;
static String status;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.splash);
new Controller();
Register register = Controller.hundler.retriveRegisterData();
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
DeviceId = telephonyManager.getDeviceId();
Key= Utility.KeyGenration(DeviceId);
try {
Version = "v"+getPackageManager().getPackageInfo(getPackageName(), 0).versionName;
} catch (NameNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if(register == null)
{
final AlertDialog dialog = new AlertDialog.Builder(this).create();
dialog.setTitle(getString(R.string.app_name));
dialog.setMessage("Enter Email here");
LayoutInflater inflate = this.getLayoutInflater();
View view = inflate.inflate(R.layout.dialog_layout, null);
dialog.setView(view);
dialog.show();
final EditText email = (EditText) view.findViewById(R.id.editText1);
Button ok = (Button) view.findViewById(R.id.button1);
ok.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Email = email.getText().toString();
RefrashTask task = new RefrashTask();
task.execute();
dialog.dismiss();
}
});
}
}
传递给数据库处理程序的上下文不是有效的上下文
Controller
是一个应用程序
,但在您的活动onCreate()
中,您可以使用new
初始化它。这是不允许的。您应该通过在清单中声明来初始化应用程序
类。您可以在onCreate()
中使用应用程序作为上下文,但不能在早期使用,例如在构造函数中。显示您的启动类。@Ahmad提供您试图创建数据库实例或试图打开数据库的代码。为什么您要从活动中调用应用程序类?您是否在清单中将控制器类定义为应用程序?始终先启动应用程序类,然后再启动活动。此函数RetriverRegisterData()的作用是什么?代码在哪里?非常感谢@GrIsHu我的问题解决方案我的错误是我在活动中创建了控制器对象,而不是在menifest文件中定义
public class Splash extends Activity
{
static String DeviceId;
static String Key;
static String Email;
static String Version;
static String status;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.splash);
new Controller();
Register register = Controller.hundler.retriveRegisterData();
TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
DeviceId = telephonyManager.getDeviceId();
Key= Utility.KeyGenration(DeviceId);
try {
Version = "v"+getPackageManager().getPackageInfo(getPackageName(), 0).versionName;
} catch (NameNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if(register == null)
{
final AlertDialog dialog = new AlertDialog.Builder(this).create();
dialog.setTitle(getString(R.string.app_name));
dialog.setMessage("Enter Email here");
LayoutInflater inflate = this.getLayoutInflater();
View view = inflate.inflate(R.layout.dialog_layout, null);
dialog.setView(view);
dialog.show();
final EditText email = (EditText) view.findViewById(R.id.editText1);
Button ok = (Button) view.findViewById(R.id.button1);
ok.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Email = email.getText().toString();
RefrashTask task = new RefrashTask();
task.execute();
dialog.dismiss();
}
});
}
}
public class Controller extends Application
{
public static DatabaseHundler hundler ;
public Controller() {
hundler = DatabaseHundler.getInstance(this);
}
}