1

logcatでこのエラーが発生しました

06-21 11:58:27.275: E/AndroidRuntime(404): java.lang.RuntimeException: Unable to start activity ComponentInfo{App.Biodata/App.Biodata.viewdata}: java.lang.NullPointerException
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.os.Handler.dispatchMessage(Handler.java:99)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.os.Looper.loop(Looper.java:123)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread.main(ActivityThread.java:4627)
06-21 11:58:27.275: E/AndroidRuntime(404):  at java.lang.reflect.Method.invokeNative(Native Method)
06-21 11:58:27.275: E/AndroidRuntime(404):  at java.lang.reflect.Method.invoke(Method.java:521)
06-21 11:58:27.275: E/AndroidRuntime(404):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
06-21 11:58:27.275: E/AndroidRuntime(404):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
06-21 11:58:27.275: E/AndroidRuntime(404):  at dalvik.system.NativeStart.main(Native Method)
06-21 11:58:27.275: E/AndroidRuntime(404): Caused by: java.lang.NullPointerException
06-21 11:58:27.275: E/AndroidRuntime(404):  at App.Biodata.viewdata.onCreate(viewdata.java:42)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
06-21 11:58:27.275: E/AndroidRuntime(404):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
06-21 11:58:27.275: E/AndroidRuntime(404):  ... 11 more

Java ファイル:

package App.Biodata;

import java.util.ArrayList;
import java.util.HashMap;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.ListActivity;
import android.os.Bundle;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;


public class viewdata extends ListActivity {

private static String link_url = "http://10.0.2.2/biodatawebservice/view.php";

private static final String BIO_NAMA = "nama";
private static final String BIO_ALAMAT = "alamat";
private static final String BIO_TGLLAHIR = "tgl_lahir";
private static final String BIO_JK = "jk";
private static final String BIO_EMAIL = "email";    
private static final String BIO_PHONE = "phone";

JSONArray biodata = null;

ArrayList<HashMap<String, String>> daftar_biodata = new ArrayList<HashMap<String, String>>();

/** Called when the activity is first created. */
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.viewdata);
    
    JSONParser jParser = new JSONParser();

    JSONObject json = jParser.AmbilJson(link_url);
    
    try {
        biodata = json.getJSONArray("biodata");
        
        for(int i = 0; i < biodata.length(); i++){
            JSONObject bio = biodata.getJSONObject(i);
            
            String nama = bio.getString(BIO_NAMA);
            String alamat = bio.getString(BIO_ALAMAT);
            String tgl_lahir = bio.getString(BIO_TGLLAHIR);
            String jk = bio.getString(BIO_JK);
            String email = bio.getString(BIO_EMAIL);
            String phone = bio.getString(BIO_PHONE);
            
            HashMap<String, String> map = new HashMap<String, String>();

            map.put(BIO_NAMA, nama);
            map.put(BIO_ALAMAT, alamat);
            map.put(BIO_TGLLAHIR, tgl_lahir);
            map.put(BIO_JK, jk);
            map.put(BIO_EMAIL, email);
            map.put(BIO_PHONE, phone);

            daftar_biodata.add(map);
        }
    } catch (JSONException e) {
        e.printStackTrace();
    }
    this.adapter_listview();
}       

private void adapter_listview() {
    // TODO Auto-generated method stub
    ListAdapter adapter = new SimpleAdapter(this, daftar_biodata,
            R.layout.list_data,
            new String[] {  BIO_NAMA, BIO_ALAMAT, BIO_TGLLAHIR, BIO_JK, BIO_EMAIL, BIO_PHONE}, new int[] {
                    R.id.txtNama, R.id.txtAlamat, R.id.txtTgllahir, R.id.txtJK, R.id.txtEmail,R.id.txtPhone});

    setListAdapter(adapter);
    ListView lv = getListView();


}

}

listactivity の 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:orientation="vertical" >

<ListView
    android:id="@android:id/list"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >
</ListView>

</LinearLayout>

各アイテムのxml:

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Nama"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtNama"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Alamat"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtAlamat"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Tanggal Lahir"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtTgllahir"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Jenis Kelamin"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtJK"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Telepon"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtPhone"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingBottom="10dp" >

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="5dp"
        android:text="Email"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="#FFF" />

    <TextView
        android:id="@+id/txtEmail"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#333"
        android:text=" "
        android:textAppearance="?android:attr/textAppearanceMedium" />
</LinearLayout>


</LinearLayout>

このアプリの何が問題なのかわかりません。このアプリが強制終了する理由を誰か教えてもらえますか? 私はすでに答えのいくつかをここで読んでいますが、xmlレイアウトファイルに何か問題があることを伝えていますが、それでも解決策が見つかりません

前もって感謝します。

[解決済み]

私を助けてくれたstackoverflow.comのメンバーに感謝します。問題はこれです

biodata = json.getJSONArray("バイオデータ");

私のphpが失敗するため、nullです。

4

5 に答える 5

1

さて、あなたはログを正しく読むことを学ぶべきだと思います。logcatが言っていることから問題を検出することがより重要です。だからここにあなたがそれをすることができる方法があります:

まず、IDEで行番号を有効にします。次に、logcatで問題がどのように記述されているかを見てみましょう。

     java.lang.RuntimeException: Unable to start activity componentInfo{App.Biodata/App.Biodata.viewdata}: java.lang.NullPointerException   

したがって、viewdataクラスでnullポインタ例外がスローされます。これは、nullオブジェクトからメソッドにアクセスしようとしたために発生しています。

第三に、問題の原因を探し続けます。

   Caused by: java.lang.NullPointerException   E/AndroidRuntime(404):  at App.Biodata.viewdata.onCreate(viewdata.java:42).    

したがって、問題は行番号42のviewdata.javaにあります。

于 2012-06-21T12:29:55.017 に答える
1

json is nullしたがって、NPE.JsonParserからJsonObjectを取得することはできません。

biodata = json.getJSONArray("biodata");//here json is null.

とあなたのチェックjson = jParser.AmbilJson(link_url);

ListView lv = getListView();そして、listviewへのsetAdapterの後の使用はありません。

于 2012-06-21T12:26:17.577 に答える
0

ここにエラーがあります

 biodata = json.getJSONArray("biodata");

あなたは条件を入れなければなりません

if(json!=null)
{
    biodata = json.getJSONArray("biodata");
}

あなたjParser.AmbilJson(link_url);は失敗しているに違いない

于 2012-06-21T12:30:22.967 に答える
0

以下の行にエラーがあると思います。

ListView lv = getListView();

以下で使用してください。

ListView lv = (ListView) findViewById(R.id.list);

lv = getListView();
于 2012-06-21T12:28:06.080 に答える
0

アクティビティを List アクティビティとして拡張し、XML レイアウトにアクセスしようとします。setContentView(R.layout.viewdata); を削除してください。

ありがとう

于 2012-06-21T12:28:51.727 に答える