从一个活动转移到另一个活动时,它显示一个空指针异常,但我无法找到错误发生的位置。
将我的logcat提供给
10-04 12:14:10.876: E/AndroidRuntime(1966): FATAL EXCEPTION: main
10-04 12:14:10.876: E/AndroidRuntime(1966): java.lang.RuntimeException: Unable to start
activity ComponentInfo{com.neochat/com.neochat.Displayfriendlist}:
java.lang.NullPointerException
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread.access$600(ActivityThread.java:141)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.os.Handler.dispatchMessage(Handler.java:99)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.os.Looper.loop(Looper.java:137)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread.main(ActivityThread.java:5041)
10-04 12:14:10.876: E/AndroidRuntime(1966): at java.lang.reflect.Method.invokeNative(Native Method)
10-04 12:14:10.876: E/AndroidRuntime(1966): at java.lang.reflect.Method.invoke(Method.java:511)
10-04 12:14:10.876: E/AndroidRuntime(1966): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
10-04 12:14:10.876: E/AndroidRuntime(1966): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
10-04 12:14:10.876: E/AndroidRuntime(1966): at dalvik.system.NativeStart.main(Native Method)
10-04 12:14:10.876: E/AndroidRuntime(1966): Caused by: java.lang.NullPointerException
10-04 12:14:10.876: E/AndroidRuntime(1966): at com.neochat.LoginDataBaseAdapter.Displayfriend(LoginDataBaseAdapter.java:110)
10-04 12:14:10.876: E/AndroidRuntime(1966): at com.neochat.Displayfriendlist.onCreate(Displayfriendlist.java:25)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.Activity.performCreate(Activity.java:5104)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
10-04 12:14:10.876: E/AndroidRuntime(1966): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
10-04 12:14:10.876: E/AndroidRuntime(1966): ... 11 more
在下面提供我的java课程
public class DisplayFriendList extends Activity {
Context context = this;
LoginDataBaseAdapter Logi;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.displayfriend);
Logi = new LoginDataBaseAdapter(this);
Bundle data = getIntent().getExtras();
String code = data.getString("EMPCode");
String gotfriend = Logi.Displayfriend(code);
TextView txt = (TextView) findViewById(R.id.getfriend);
txt.setText(gotfriend);
Button btnadd = (Button) findViewById(R.id.data_addfriend);
btnadd.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
// Logi.insertFriendEntry(String Name, String Emp_Code);
Toast.makeText(context, "Friend added successfully",
Toast.LENGTH_SHORT).show();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// TODO Auto-generated method stub
return super.onCreateOptionsMenu(menu);
}
}
给出函数Displayfriend ..in LoginDataBaseAdapter class
public String DisplayFriend(String Emp_Code) {
String displayfriend = "SELECT NAME , EMPLOYEE_CODE FROM EMPLOYEES " +
"WHERE " + " EMPLOYEE_CODE " + "LIKE '" +Emp_Code;
Cursor display = db.rawQuery(displayfriend, null);
String data = display.getString(0);
return data;
}
答案 0 :(得分:0)
此行引发异常:String gotfriend=Logi.Displayfriend(code);
因为Logi
var等于null。 Logi
为空,因为初始化存在问题,您应该检查Logi=new LoginDataBaseAdapter(this);
和LoginDataBaseAdapter
的构造函数以查看是否存在任何错误。
如果您发布适配器的代码和第二个活动,我会尝试更精确。
注意:您应该至少遵循命名方法和变量的“java良好实践”。非静态方法应以小写字母开头。非final var应以小写字母开头。
答案 1 :(得分:0)
我认为问题出在DisplayFriend方法
中在从游标检查中重新获取数据之前,如果游标为空,则该游标为空或不通过异常。我认为这就是问题所在。
答案 2 :(得分:0)
哪一行是#110?如果它是第一个(字符串显示...)然后检查Emp_Code。如果它是第三个(字符串数据......),那么使用它:
if (display==null) return null; //or ""
if (!display.moveToFirst()) return null;
//the rest of your code
答案 3 :(得分:0)
解决此类错误的简单方法是查看日志猫。
LoginDataBaseAdapter.Displayfriend(LoginDataBaseAdapter.java:110)
双击此行,您将被重定向到显示的行,根据代码,确定可能导致空指针的内容。对象未实例化,否则数据库不返回任何数据。