我正在尝试创建一个 android 应用程序,该应用程序可以使用他选择的名称存储用户位置(手机信号塔代码),例如手机信号塔代码是 405673,我想将其存储为“家”位置。所以,基本上我的程序包含以下模块
- 获取用户塔代码。
- 创建一个数据库。
- 从用户那里获取位置名称的输入字符串。
- 将这些值存储在数据库中。
- 在请求时显示这些值。
模块 1 和 2 分别完美地工作,但是当我将它们集成时,我得到一个致命的 main 和一个空指针异常。
我的代码如下
package my.project.mil;
import android.content.Context;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class Cbdata extends MainActivity {
public String str;
public void onReceive(Context context, Intent intent) {
//---get the CB message passed in---
Bundle bundle = intent.getExtras();
SmsCbMessage[] msgs = null;
str = "";
if (bundle != null) {
//---retrieve the SMS message received---
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsCbMessage[pdus.length];
for (int i=0; i<msgs.length; i++) {
msgs[i] = SmsCbMessage.createFromPdu((byte[])pdus[i]);
str += "CB " + msgs[i].getGeographicalScope() + msgs[i].getMessageCode() + msgs[i].getMessageIdentifier() + msgs[i].getUpdateNumber();
str += " :";
str += msgs[i].getMessageBody().toString();
str += "\n";
}}
}
SQLiteDatabase cd = openOrCreateDatabase("mydata", MODE_WORLD_READABLE, null);
Button submit;
Button viewdb;
EditText name;
@Override
public void onCreate(Bundle savedInstanceState)
{
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.seventh);
viewdb = (Button) findViewById(R.id.viewdb);
submit = (Button) findViewById(R.id.submit);
name = (EditText) findViewById(R.id.name);
submit.setOnClickListener(new View.OnClickListener()
{
public void onClick(View arg0) {
String locname = name.getText().toString();
if (locname.length()>0)
{
cd.execSQL("CREATE TABLE IF NOT EXITSTS MLITable (CblocationCode INT(10), CblocationName VARCHAR);");
cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');" +str +locname);
Toast.makeText(getBaseContext(), "value successfully entered.", Toast.LENGTH_LONG).show();
}
else
{
Toast.makeText(getBaseContext(), "Please enter the location name, for example 'Home'.", Toast.LENGTH_LONG).show();
}
}
});
cd.close();
viewdb.setOnClickListener(new View.OnClickListener()
{
public void onClick(View arg0) {
// TODO Auto-generated method stub
// here comes the code for viewing the database
}
});
}
}
我的logcat如下
有趣的是,我删除了数据库命令以查看我的代码是否正常工作,由此我可以得出结论,我在数据库连接线中犯了一个错误。
现在,我的查询是
- 为什么我的数据库连接出现空点异常错误,我该如何解决?
我使用以下代码将值插入表中,
cd.execSQL("如果不存在则创建表 MLITable (CblocationCode INT(10), CblocationName VARCHAR);"); cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');" +str +locname); 将用户值传递给我的数据库的正确方法是什么?
谢谢你。