[英]Android Null Pointer Exception when Creating Database
我有一个示例应用程序,它创建一个数据库,表并插入一行值。
这是我的MainActivity.java
:
public class MainActivity extends Activity {
protected static final android.content.Context Context = null;
public String ReadingMode="";
@Override
protected void onCreate(Bundle savedInstanceState) {
SQLiteDatabase sampleDB = Context.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
sampleDB.execSQL("CREATE TABLE IF NOT EXISTS " +
"SampleTable " +
" (LastName VARCHAR, FirstName VARCHAR," +
" Country VARCHAR, Age INT(3));");
sampleDB.execSQL("INSERT INTO " +
"SampleTable " +
" Values ('Makam','sample','India',25);");
sampleDB.close();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
当我逐行调试时,在该行附近引发Null pointer exception
:
SQLiteDatabase sampleDB = Context.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
我看到sampleDB
为空,并且没有创建Database
。
我的代码有什么问题吗?
您正在使用null初始化Context
protected static final android.content.Context Context = null;
因此,当您使用空Context时,它将抛出NPE,您可以使用Activity Context设置Context,然后使用Context
Context = MainActivity.this;
或只是使用这个
SQLiteDatabase sampleDB = this.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
您正在初始化为protected static final android.content.Context Context = null;
然后将其用作Context.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
显然会产生空指针异常。
皇室
SQLiteDatabase sampleDB = Context.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
与
SQLiteDatabase sampleDB = this.openOrCreateDatabase("WaterElectricityReading", MODE_WORLD_READABLE, null);
原因:
Activity
是Context
子类,因此可以使用this
。 openOrCreateDatabase
不是静态方法,因此您不能使用类名来调用它。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.