threadid = 1:线程退出,未捕获异常(group = 0xb4af3b90)

时间:2013-12-13 11:27:59

标签: android eclipse fatal-error

我是android dev的新手,我开始学习如何将一项活动改为另一项活动。我已经学会了用不同的工具来实现它,比如应用程序发明者,android工作室直到eclipse。但是,我有相同的错误,如果我点击按钮做另一个活动,这样的力量关闭。这是我的示例代码让我感到困惑。我使用eclipse。

这是我的主要活动

package com.kontak.latihan;

import com.latihan.kontak.form.MenuForm;

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.View;
import android.view.View.OnClickListener;

public class KontakActivity extends Activity implements OnClickListener {

private MenuForm form;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_kontak);

    form = new MenuForm(this);

    form.getButtonBuatKontakBaru().setOnClickListener(this);
    form.getButtonDaftarKontak().setOnClickListener(this);
}

public void onClick(View v){
    if(v == form.getButtonBuatKontakBaru()){
        Intent intent = new Intent(this, BuatActivity.class);
        startActivity(intent);
    }

}


}

这是我的其他活动

package com.kontak.latihan;

import com.kontak.latihan.database.KontakDatabase;
import com.kontak.latihan.model.Kontak;
import com.latihan.kontak.form.BuatForm;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;

public  class BuatActivity extends Activity implements OnClickListener{

private BuatForm form;


@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.buat);

    form = new BuatForm(this);

    form.getButtonSimpan().setOnClickListener(this);
}



@Override
public void onClick(View v) {
    // TODO Auto-generated method stub
    Kontak kontak = new Kontak();
    kontak.nama = form.getEditTextNama().getText().toString();
    kontak.telepon = form.getEditTextTelepon().getText().toString();
    kontak.email = form.getEditTextEmail().getText().toString();

    KontakDatabase database = KontakDatabase.getInstance();
    database.add(kontak);

    // reset
    form.reset();
}





}

这是我的清单文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.kontak.latihan"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="19" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.kontak.latihan.KontakActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity 
        android:label="Buat Kontak Baru"
        android:name=".BuatActivity">
    </activity>
     <activity 
        android:label="Buat Daftar Baru"
        android:name=".DaftarActivity">
    </activity>
</application>

</manifest>

这是我的错误日志

12-13 10:09:13.706: E/AndroidRuntime(357): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.kontak.latihan/com.kontak.latihan.KontakActivity}: java.lang.NullPointerException
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.os.Handler.dispatchMessage(Handler.java:99)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.os.Looper.loop(Looper.java:123)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread.main(ActivityThread.java:3683)
12-13 10:09:13.706: E/AndroidRuntime(357):  at java.lang.reflect.Method.invokeNative(Native Method)
12-13 10:09:13.706: E/AndroidRuntime(357):  at java.lang.reflect.Method.invoke(Method.java:507)
12-13 10:09:13.706: E/AndroidRuntime(357):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
12-13 10:09:13.706: E/AndroidRuntime(357):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
12-13 10:09:13.706: E/AndroidRuntime(357):  at dalvik.system.NativeStart.main(Native Method)
12-13 10:09:13.706: E/AndroidRuntime(357): Caused by: java.lang.NullPointerException
12-13 10:09:13.706: E/AndroidRuntime(357):  at com.kontak.latihan.KontakActivity.onCreate(KontakActivity.java:23)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
12-13 10:09:13.706: E/AndroidRuntime(357):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
12-13 10:09:13.706: E/AndroidRuntime(357):  ... 11 more
12-13 10:09:31.646: I/Process(357): Sending signal. PID: 357 SIG: 9

首次发布时不起作用。感谢您的关注。非常欢迎您的帮助。

2 个答案:

答案 0 :(得分:0)

form.getButtonDaftarKontak()似乎正在返回null。你应该检查一下这个方法。

提示:总是看一下堆栈跟踪中的“由...引起”。这是真正的错误经常发出信号的地方,而堆栈跟踪的顶部只是代码的其余部分由于第一个异常而失败。

答案 1 :(得分:0)

findViewById查找当前虚增布局中提到的id的视图。您可能在初始化视图时获得了NPE。

我建议你看看文档。

http://developer.android.com/training/basics/firstapp/starting-activity.html

Button form;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_kontak);
    form = (Button)findViewById(R.id.buttonForm);
    // buttonForm is the id of button in activity_kontak
    form.setOnClickListener(this);

}

另外

public class KontakActivity extends Activity

你有

Kontak kontak = new Kontak(); 

在下面的链接中查看Raghav Sood的答案。此外,如果您需要将值从一个Activity传递到另一个Activity使用意图。

Can i Create the object of a activity in other class?