我正在使用存储特定信息的数据库开发项目。数据库适用于部分程序,但对于其他程序则不然。当用户首次启动程序时,他们将看到从数据库中提取的信息,并且还可以选择添加新信息。数据库适用于这两种方法。
我遇到的问题是另一个添加信息的地方。当我打开数据库时,我的程序崩溃了。 logcat的:
08-29 20:22:47.000: E/AndroidRuntime(3022): FATAL EXCEPTION: main
08-29 20:22:47.000: E/AndroidRuntime(3022): java.lang.NullPointerException
08-29 20:22:47.000: E/AndroidRuntime(3022): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
08-29 20:22:47.000: E/AndroidRuntime(3022): at android.database.sqlite.SQLiteOpenHelper._getWritableDatabase(SQLiteOpenHelper.java:164)
08-29 20:22:47.000: E/AndroidRuntime(3022): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:100)
08-29 20:22:47.000: E/AndroidRuntime(3022): at peices.DbM.open(DbM.java:173)
08-29 20:22:47.000: E/AndroidRuntime(3022): at peices.NewStuff.CreateNewUnit(NewStuff.java:27)
08-29 20:22:47.000: E/AndroidRuntime(3022): at carlson.msum.arch.Site$5.onClick(Site.java:231)
08-29 20:22:47.000: E/AndroidRuntime(3022): at android.view.View.performClick(View.java:2538)
NewStuff代码:27(第20-30行):
bb=Lon.getText().toString();
cc=UnitName.getText().toString();
Log.d("Class",aa);
Log.d("Class",bb);
Log.d("Class",cc);
Log.d("Class",SiteName);
Log.d("Stuff","Before Open");
**db.open();**
Log.d("Stuff","Before Insert/After Open");
db.InsertUnit(SiteName, cc, aa, bb);
Log.d("Stuff","Before Close/After Insert");
db.close();
DbM.java代码:173(170-176)
public DbM open() throws SQLException
{
Log.d("BmDb","open");
**db= DbMh.getWritableDatabase();**
Log.d("BmDb","Open before return");
return this;
}
我已经知道它与db的开放有关,但为什么它会打开并为其他活动工作,但不是这个?我检查了所有活动,然后我关闭了所有的数据库。
这是课程的开始,DbM初始化是我为所有其他人做的。
public class NewStuff extends Activity {
Context context;
**DbM db=new DbM(this);**
可能有一件事,但不确定如何解决这个问题,这是我在程序的其他部分使用的一类对象。所以我没有打电话给任何创造或类似的东西,这会导致我的问题吗?
*的 修改 *
这是我的整个NewStuff类,我必须缺少其他的东西,只有上下文,因为似乎没有任何工作。
package peices;
import peices.DbM;
import android.os.Bundle;
import android.util.Log;
import android.widget.EditText;
import android.app.Activity;
import android.content.Context;
public class NewStuff extends Activity {
Context context;
DbM db;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
db=new DbM(this);
}
public void CreateNewUnit(EditText Lat, EditText Lon, EditText UnitName, String SiteName)
{
db=new DbM(this);
Log.d("NewUnit","Start of");
String aa="";
String bb="";
String cc="";
aa=Lat.getText().toString();
bb=Lon.getText().toString();
cc=UnitName.getText().toString();
Log.d("Class",aa);
Log.d("Class",bb);
Log.d("Class",cc);
Log.d("Class",SiteName);
Log.d("Stuff","Before Open");
db.open();
Log.d("Stuff","Before Insert/After Open");
db.InsertUnit(SiteName, cc, aa, bb);
Log.d("Stuff","Before Close/After Insert");
db.close();
}
修改 的
调用NewStuff的onclick函数
ucreate.setOnClickListener(new OnClickListener(){
public void onClick(View m){
Log.d("Ubox","Unit Name: "+uname.getText().toString());
Log.d("Ubox","Unit Longitude: "+ulon.getText().toString());
Log.d("Ubox","Unit Latitude: "+ulat.getText().toString());
Log.d("Ubox","Site Name: "+SiteName);
NewStuff ns= new NewStuff();
ns.CreateNewUnit(ulat,ulon,uname,SiteName);
Intent I= new Intent(Site.this, Site.class);
I.putExtra("SITE", SiteName);
startActivity(I);
答案 0 :(得分:1)
您无法将DbM初始化为字段,因为上下文不会被初始化
DbM db=new DbM(this);
致电
db=new DbM(this);
仅在OnCreate中或之后。
编辑: 你不能打电话
NewStuff ns= new NewStuff()
这是因为如果您自己实例化,则不会设置活动的上下文。因此,新DbM(this); 中的this
没有任何意义。
主要是你通常不应该将一个函数称为另一个Activity的活动。
答案 1 :(得分:1)
以这种方式定义db
public class NewStuff extends Activity {
Context context;
DbM db;
然后onCreate(
onCreate(){
........
db=new DbM(this);
}
这就是@nandeesh试图告诉你的事情。