4

良い一日。Android プロジェクト、特にリストビューで問題が発生しています。このサイトで他の情報を検索してみて、いくつかの回答を実装しました。ただし、まだ機能していません。

エラーは具体的には

MainActivity の 76 行目の NullPointerException

ここに私のMainActivityのコードがあります

import java.util.ArrayList;

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;

public class MainActivity extends Activity {

     final ArrayList<String> studentName = new ArrayList<String>();

     ArrayAdapter<String> aa;

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



        ListView myList = (ListView) findViewById(R.id.listName);

         aa = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, studentName);

         myList.setAdapter(aa);


        //droid.R.id.list;

        //add
        Button bAdd = (Button) findViewById(R.id.addstudent);
        bAdd.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {
                startActivity(new Intent("android.intent.action.ADDSTUDENTS"));
            }   
        });


        //edit

        Button bEdit = (Button) findViewById(R.id.editstudent);
        bEdit.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View x) {
                startActivity(new Intent("android.intent.action.EDITSTUDENTS"));
            }
        });

        //edit

        Button bDelete = (Button) findViewById(R.id.deletestudent);
        bDelete.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View x) {
                startActivity(new Intent("android.intent.action.DELETESTUDENTS"));
                }
            });


    }

    public ArrayList<String> getArray(){
        return studentName;
    }

    public void notifyArray(){
        aa.notifyDataSetChanged();
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

}

ちなみに76行目は

aa.notifyDataSetChanged();

AddStudents クラスのコードは次のとおりです。

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

public class AddStudents extends Activity{

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);

        setContentView(R.layout.add_student);

        Button bAddStudents = (Button) findViewById(R.id.add);
        final EditText et = (EditText) findViewById(R.id.student_name);

        bAddStudents.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {

                MainActivity as = new MainActivity();

                as.getArray().add(et.getText().toString());
                as.notifyArray();
                finish();

            }   


        });

        Button bBack = (Button) findViewById(R.id.backadd);

        bBack.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {

                finish();

            }   
    });


    }

}

リストビューを含むxml部分は

 <ListView
            android:id="@+id/listName" 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1" >

        </ListView>

私も自分の過ちが何であるかを知りたいので、あなたが私を助けてくれることを願っています. 必要に応じて他の情報を追加できます。

4

3 に答える 3

3

あなたのクラスでは、インスタンス化した直後にAddStudents呼び出しています。インスタンス化するだけでは呼び出されません。notifyArray()MainActivityMainActivity.onCreate()

あなたのインスタンス化はおそらくあなたが望むものではありません(そのオブジェクトはハンドラーが完了MainActivityした直後に破棄されるため)。onClick

代わりに、の既存のインスタンスにアクセスする必要がありますMainActivity。そのためには、現在のインスタンスへの参照をMainActivityクラスの静的メンバーに追加します。

public class MainActivity extends Activity {
    public static MainActivity activity;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        activity = this;
    }
}

次に、AddStudentクラスで次の方法でアクセスします

MainActivity.activity.notifyArray()

MainActivityこれは問題を解決するための最も美しい方法ではありませんが、インスタンスが 1 つしかないことを確認できる限り機能します。(そうでない場合は、配列自体を静的にするか、Singleton ラッパー クラスを作成することができます。)

于 2013-01-07T12:30:35.787 に答える
1

notifyArray()は前に呼び出されていonCreateます。

于 2013-01-07T12:16:35.253 に答える
0

getArray().add(et.getText().toString()); を呼び出してみてください。およびnotifyArray(); MainActivity の onResume() 内で、AddStudentActivity からではありません (推奨されません!)

したがって、 onResume() 理想的には新しい学生をリストに追加したいので、あなたの場合、ハッシュテーブルなどの共通の共有可能なオブジェクトを使用して学生の名前を取得し、それをシングルトンにして、どこからでも使用できますアプリケーションで

共通クラスは次のようになります。

class CommonHashtable{

private static Hashtable<String, Object> commonHashtable = null;

public static getInstance(){
    if(commonHashtable == null)
        commonHashtable = new Hashtable<String, Object>();

    return commonHashtable;
}

getInstance() では、一時的に値を格納するために使用できる commonHashtable を返します!

したがって、これを addbutton クリックイベントに追加します

Hashtable hash = CommonHashtable.getInstance();
hash.put("NEW_STUDENT_NAME", et.getText().toString());

これを MainActivity の onResume() に追加します

Hashtable hash = CommonHashtable.getInstance();
Object studentName = (String) hash.get("NEW_STUDENT_NAME");

if(studentName != null){
    notifyArray();
}
于 2013-01-07T13:05:57.223 に答える