-1

あるアクティビティから別のアクティビティに移動すると、null ポインター例外が表示されますが、エラーが発生している場所を見つけることができませんでした。

以下に私の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 クラスを与える

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;
}
4

4 に答える 4

0

このようなエラーを解決する簡単な方法は、log cat を確認することです。

LoginDataBaseAdapter.Displayfriend(LoginDataBaseAdapter.java:110)

この行をダブルクリックすると、示されている行にリダイレクトされます。コードに基づいて、null ポインターの原因を特定します。オブジェクトがインスタンス化されていないか、データベースがデータを返していません。

于 2013-10-04T17:01:43.880 に答える
0

110番は何番線?最初のもの(文字列表示...)の場合は、Emp_Codeを確認してください。3 番目 (文字列データ...) の場合は、次を使用します。

if (display==null) return null; //or ""
if (!display.moveToFirst()) return null;
//the rest of your code
于 2013-10-04T16:28:55.483 に答える
0

この行で例外が発生します: var が null に等しいためですString gotfriend=Logi.Displayfriend(code);。は null で、初期化に問題があるため、のコンストラクターをチェックして、エラーがないかどうかを確認する必要があります。 LogiLogiLogi=new LoginDataBaseAdapter(this);LoginDataBaseAdapter

アダプターのコードと 2 番目のアクティビティを投稿すると、より正確になるように努めます。

注: メソッドと変数に名前を付けるには、少なくとも「Java の推奨事項」に従う必要があります。非静的メソッドは小文字で始める必要があります。非最終変数は小文字で始める必要があります。

于 2013-10-04T12:58:17.503 に答える
0

問題は DisplayFriend メソッドにあると思います

カーソルチェックからデータを取得する前に、カーソルがnullであるかどうか、またはnullの場合は例外が発生するかどうかを確認します。それが問題だと思います。

于 2013-10-04T13:30:50.200 に答える