我正在努力找出這一個out.When我點擊我的活動它崩潰與NullPointerException.I試過調試,但我無法進入有問題的活動。我是嘗試刪除數據庫,仍然崩潰。我試圖刪除ListView,仍崩潰。我試圖修改數據庫,仍然崩潰。空指針異常
由於某些奇怪的原因,當我在「playbutton」上刪除按鈕及其onClickListener時,我能夠進入活動並且活動中的所有內容都能正常工作。有人可以幫助我解釋爲什麼此按鈕會導致應用程序崩潰該活動,而不是onclick?
04-05 23:15:15.886: E/AndroidRuntime(11445): FATAL EXCEPTION: main
04-05 23:15:15.886: E/AndroidRuntime(11445): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.fullfrontalgames.numberfighter/com.fullfrontalgames.numberfighter.PlayAFriend}: java.lang.NullPointerException
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2136)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2174)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread.access$700(ActivityThread.java:141)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1267)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.os.Handler.dispatchMessage(Handler.java:99)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.os.Looper.loop(Looper.java:137)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread.main(ActivityThread.java:5059)
04-05 23:15:15.886: E/AndroidRuntime(11445): at java.lang.reflect.Method.invokeNative(Native Method)
04-05 23:15:15.886: E/AndroidRuntime(11445): at java.lang.reflect.Method.invoke(Method.java:511)
04-05 23:15:15.886: E/AndroidRuntime(11445): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
04-05 23:15:15.886: E/AndroidRuntime(11445): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555)
04-05 23:15:15.886: E/AndroidRuntime(11445): at dalvik.system.NativeStart.main(Native Method)
04-05 23:15:15.886: E/AndroidRuntime(11445): Caused by: java.lang.NullPointerException
04-05 23:15:15.886: E/AndroidRuntime(11445): at com.fullfrontalgames.numberfighter.PlayAFriend.onCreate(PlayAFriend.java:54)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.Activity.performCreate(Activity.java:5058)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
04-05 23:15:15.886: E/AndroidRuntime(11445): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2100)
活動
package com.fullfrontalgames.numberfighter;
import com.fullfrontalgames.numberfighter.DBAdapter;
import com.fullfrontalgames.numberfighter.R;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.os.Bundle;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.View;
import android.widget.Button;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class PlayAFriend extends Activity{
DBAdapter DBAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.playafriend);
final DBAdapter db = new DBAdapter(this);
DBAdapter = db.open();
ListView FriendLV = (ListView) findViewById(android.R.id.list);
Button playbutton = (Button) findViewById(R.id.playbutton);
final TextView friend = (TextView) findViewById(R.id.textview_friends);
Cursor friendslist = db.GetAllFriends();
String[] from = new String[] {"FRIENDS"}; // your column/columns here
int[] to = new int[] {R.id.textview_friends};
@SuppressWarnings("deprecation")
ListAdapter cursorAdapter = new SimpleCursorAdapter(this, R.layout.list_items, friendslist, from, to,0);
FriendLV.setAdapter(cursorAdapter);
playbutton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
String Defender = friend.getText().toString();
db.GetFriend(Defender);
startActivity(new Intent ("com.fullfrontalgames.numberfighter.Fightattacker"));
db.close();
}
});
}
}
playafriend XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/nfbackground"
android:orientation="vertical" >
<ImageView
android:id="@id/titlebar"
android:layout_width="wrap_content"
android:layout_height="66dp"
android:src="@drawable/nftitlebar" />
<ListView
android:id="@android:id/list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
</ListView>
</LinearLayout>
list_items XML
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="5dp"
android:background="@drawable/searchimageview"
android:orientation="vertical" >
<Button
android:id="@+id/playbutton"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_gravity="right"
android:background="@drawable/playbutton" />
<TextView
android:id="@+id/textview_friends"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/black"
android:textStyle="bold"
android:textSize="40dp"
android:layout_gravity="center" />
</FrameLayout>
</LinearLayout>
請加滿堆棧跟蹤擴展ListActivity。 – BobTheBuilder 2013-04-06 03:31:15
你可能不應該有這些行DBAdapter DBAdapter;和DBAdapter = db.open();相反,db.open();應該就夠了。無論如何,朋友或數據庫都是空的。請發佈logcat錯誤消息。 – Luis 2013-04-06 03:36:17
發佈你的logcat會更好地理解你的問題。另請發佈您的佈局文件代碼。 – GrIsHu 2013-04-06 03:38:00