android - List<Class> 上的空指针异常

标签 android listview android-sqlite

所以我有下面的类,代码如下:

private List<Medicines> meds = new ArrayList<Medicines>();//for loading the list 
private List<Medicines> medDummy = new ArrayList<Medicines>();//for loading the list to a class
DatabaseHandler db;


@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.medicine_list);
    populateMedicines();// Null Pointer Exception
    populateListView();
}
private void populateMedicines(){
    meds = db.getOnQuery("post", "SY");// Null Pointer Exception
    for(Medicines medList: meds){
        medDummy.add(new Medicines(medList.getBrand(), medList.getDescription(), medList.getCategory()));
    }
}

public void populateListView(){
    ArrayAdapter<Medicines> adapter = new MyListAdapter();
    ListView list = (ListView)findViewById(R.id.medicineList);
    list.setAdapter(adapter);
}

public class MyListAdapter extends ArrayAdapter<Medicines>{

    public MyListAdapter(){
        super(TabsandCapsList.this, R.layout.med_layout, medDummy);
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        View itemView = convertView;
        if(itemView == null){
            itemView = getLayoutInflater().inflate(R.layout.med_layout, parent, false);
        }
        Medicines listMed = medDummy.get(position);
        //textview
        TextView header = (TextView)itemView.findViewById(R.id.list_header);
        header.setText(listMed.getBrand());
        TextView description = (TextView)itemView.findViewById(R.id.list_description);
        description.setText(listMed.getDescription());
        TextView category = (TextView)itemView.findViewById(R.id.list_category);
        category.setText(listMed.getCategory());
        return itemView;
    }


}

getOnQuery 方法:

//Getting on query medical entries
    public List<Medicines> getOnQuery(String query, String value){
        List<Medicines> medList = new ArrayList<Medicines>();

        //Query
        String queryString = "SELECT * FROM "+TABLE_MEDICINE+" WHERE "+query+" = "+"'"+value+"'";
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor c = db.rawQuery(queryString, null);

        if(c.moveToFirst()){
            do{
                Medicines med = new Medicines();
                med.setID(Integer.parseInt(c.getString(0)));
                med.setBrand(c.getString(1));
                med.setDescription(c.getString(2));
                med.setCategory(c.getString(3));
                med.setPost(c.getString(4));
                medList.add(med);
            }while(c.moveToNext());
        }
        return medList;
    }

我正在尝试用我创建的内部数据库填充我的 ListView。数据库有以下列: A。 ID b.品牌 C。类别 d.描述 e.发布

上面的函数返回列表中的 onQuery 结果。这个函数适用于我正在使用它的另一个类。但是在上面显示的类中,以下给了我一个 NPE:

09-21 23:01:25.474: E/AndroidRuntime(29321): FATAL EXCEPTION: main
09-21 23:01:25.474: E/AndroidRuntime(29321): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.geneticalabs/com.geneticalabs.TabsandCapsList}: java.lang.NullPointerException
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2211)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread.access$600(ActivityThread.java:149)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1300)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.os.Handler.dispatchMessage(Handler.java:99)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.os.Looper.loop(Looper.java:153)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread.main(ActivityThread.java:4987)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at java.lang.reflect.Method.invokeNative(Native Method)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at java.lang.reflect.Method.invoke(Method.java:511)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:821)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:584)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at dalvik.system.NativeStart.main(Native Method)
09-21 23:01:25.474: E/AndroidRuntime(29321): Caused by: java.lang.NullPointerException
09-21 23:01:25.474: E/AndroidRuntime(29321):    at com.geneticalabs.TabsandCapsList.populateMedicines(TabsandCapsList.java:75)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at com.geneticalabs.TabsandCapsList.onCreate(TabsandCapsList.java:37)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.Activity.performCreate(Activity.java:5020)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
09-21 23:01:25.474: E/AndroidRuntime(29321):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148)
09-21 23:01:25.474: E/AndroidRuntime(29321):    ... 11 more

第 37 行:

populateMedicines();

第 75 行:

meds = db.getOnQuery("post", "SY");

最佳答案

你的 db 没有初始化

DatabaseHandler db;

在你的onCreate

db = new DatabaseHandler(ActivityName.this); // initialize db

关于android - List<Class> 上的空指针异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18935391/

相关文章:

java - Android 2.3.3,在 View 中创建一行

javascript - 如何将每个选项卡链接到抽屉导航?

android - AfterTextChanged 甚至在删除监听器后调用

android - 如何在 Android 中从周日开始从 Sq-lite 检索仅 1 周的数据?

android - 哪种方法更好地以编程方式创建数据库或从 Assets 文件夹中复制它?

android - 键盘出现时保持 ListView 的底部元素可见

android - 我可以在不构建自定义 ListView 的情况下更改 ListView 样式 Android 吗?

android - 如何在未加载图像时使用 volley 解析 json 数据在 ListView 中显示背景图像

c# - 如何在虚拟模式下在所有 ListView 项上显示图标 (C#)

android - 来自 CursorWindow 的错误 : Couldn't read row 0, col -1。在访问数据之前确保 Cursor 被正确初始化