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);
    }
}