Застрял с NullPointerexception - PullRequest
       13

Застрял с NullPointerexception

1 голос
/ 25 октября 2011

Я застрял.Я пытаюсь заполнить список с полями таблицы SQLite.Я довольно новичок в программировании Android.Любой совет, почему я получаю эту ошибку:

10-24 10:24:31.154: ERROR/AndroidRuntime(1298): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dvd.clase/com.dvd.clase.Lista_Classes}: java.lang.NullPointerException
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2596)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2621)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread.access$2200(ActivityThread.java:126)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1932)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.os.Handler.dispatchMessage(Handler.java:99)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.os.Looper.loop(Looper.java:123)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread.main(ActivityThread.java:4595)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at java.lang.reflect.Method.invokeNative(Native Method)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at java.lang.reflect.Method.invoke(Method.java:521)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at dalvik.system.NativeStart.main(Native Method)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298): Caused by: java.lang.NullPointerException
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at com.dvd.clase.Lista_Classes.onCreate(Lista_Classes.java:72)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2544)
10-24 10:24:31.154: ERROR/AndroidRuntime(1298):     ... 11 more

с этим кодом (я думаю, что проблема здесь, а не в запросе SQL, но я могу ошибаться):

public class Lista_Classes extends ListActivity{
BaseDatosHelper miBBDDHelper;
private class ClasseAdapter extends ArrayAdapter<Classe> {         
        ArrayList<Classe> items;

        public ClasseAdapter(Context context, int textViewResourceId, ArrayList<Classe> items) 
        {
            super(context, textViewResourceId, items);
            this.items = items;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            View v = convertView;
            if (v == null) {
                LayoutInflater vi = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                v = vi.inflate(R.layout.lista_item, null);
            }

            Classe classe = items.get(position);

            //if (classe != null) {
                TextView tnClasse = (TextView) v.findViewById(R.id.numClasse);
                TextView tColor = (TextView) v.findViewById(R.id.Color);
                if (tnClasse != null) {
                    tnClasse.setText(classe.GetNumClase());
                }
                if (tColor != null) {
                    tColor.setText(classe.GetColor());
                }
            //}
            return v;
        }
    }



    public void crearBBDD() {
        miBBDDHelper = new BaseDatosHelper(this);
        try {
            miBBDDHelper.crearDataBase();
        } catch (IOException ioe) {
            throw new Error("Unable to create database");
        }
    }


    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        crearBBDD();

        ArrayList<Classe> classes = getItems();
        setListAdapter(new ClasseAdapter(this, R.layout.lista_item, classes));

        Button home= (Button) this.findViewById(R.id.boton_home);
        home.setOnClickListener(new View.OnClickListener() {
        public void onClick(View view){
             Intent myIntent = new Intent(view.getContext(), main.class);
              startActivityForResult(myIntent, 0);
        }

    });
    }
    public ArrayList<Classe> getItems() {
        miBBDDHelper.abrirBaseDatos();
        ArrayList<Classe> listaClasses = miBBDDHelper.GetLlistaClasses();
        miBBDDHelper.close();
        return listaClasses;
    }
}

Спасибо за ваш совет.

Ответы [ 2 ]

4 голосов
/ 25 октября 2011

Вы звоните findViewById, но никогда не настраиваете просмотр содержимого.Вы должны поместить setContentView(R.layout.yourlayout) в свой метод onCreate после вызова super.Вот почему ваша домашняя кнопка пуста.

0 голосов
/ 25 октября 2011

Согласно вашему журналу, вы должны взглянуть на строку 72 вашего файла, где-то в вашем onCreate () - я не могу узнать номера строк из кода, который вы создали.Я бы посоветовал пошагово пройти через ваш onCreate с помощью отладчика, что должно довольно быстро выявить проблему.Я предполагаю, что ваш getItems () возвращает ноль.

...