在上一篇博客(使用SQLite中自带的API操作SQLite数据库)中博主直接使用TextView显示从数据库中读取到的学生信息,其实这样做是很没有效率的,当数据库中有成百上千学生的信息时,需要一次性创建成百上千个TextView控件,这样会大大的消耗内存,实不可取的,在实际开发中也不会使用这种方式,Android中提供了一个ListView控件解决这个问题,使用ListView控件时,当从数据库中读取了很多个学生信息时,并不会直接创建多个条目,只会创建在可视区域中显示的条目,当滑动ListView控件时,被遮挡的条目会被销毁,这样可以极大地提高软件的运行效率
ListView的使用方法
1、在activity_main.xml的布局文件中添加ListView控件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.fyt.listviewdemo.MainActivity">
<ListView
android:id="@+id/lv"
android:layout_width="match_parent"
android:layout_height="match_parent">
</ListView>
</RelativeLayout>
在MainActivity中实现ListView的功能,实现的效果和上一篇博客(使用SQLite中自带的API操作SQLite数据库)的效果一样,但是执行效率比直接使用TextView的效率高
package com.fyt.listviewdemo;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends Activity {
private MyOpenHelper oh;
private SQLiteDatabase db;
private List<Student> studentList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//加载布局文件
setContentView(R.layout.activity_main);
//创建集合,保存学生的信息
studentList = new ArrayList<Student>();
//创建数据库
createDatabase();
//从数据库中读取数据
readDataFromDatabase();
//使用ListView显示学生的信息
showStudentData();
}
//创建数据库
public void createDatabase() {
//创建帮助器对象
oh = new MyOpenHelper(this, "people.db", null, 1);
//创建数据库对象
db = oh.getWritableDatabase();
}
//从数据库中读取数据
public void readDataFromDatabase() {
Cursor cursor = db.query("student", null, null, null, null, null, null, null);
while(cursor.moveToNext())
{
String name = cursor.getString(cursor.getColumnIndex("name"));
int age = cursor.getInt(cursor.getColumnIndex("age"));
int no = cursor.getInt(cursor.getColumnIndex("no"));
float cpp = cursor.getFloat(cursor.getColumnIndex("cpp"));
float math = cursor.getFloat(cursor.getColumnIndex("math"));
float english = cursor.getFloat(cursor.getColumnIndex("english"));
Log.d("MainActivity", name + ", " + age + ", " + no + ", "
+ cpp + ", " + math + ", " + english);
//将学生的信息添加到集合中
Student student = new Student(name, age, no, cpp, math, english);
studentList.add(student);
}
}
//使用ListView显示学生的信息
public void showStudentData() {
//获得布局文件上的ListView控件
ListView listView = (ListView)findViewById(R.id.lv);
//给ListView设置一个适配器
listView.setAdapter(new MyAdapter());
}
//创建一个继承自BaseAdapter的内部类
public class MyAdapter extends BaseAdapter {
//由系统调用,用于设置ListView中条目的个数
@Override
public int getCount() {
return studentList.size();
}
//由系统调用,获取一个View对象,作为ListView的条目
@Override
public View getView(int position, View convertView, ViewGroup parent) {
Student student = studentList.get(position);
TextView textView = new TextView(MainActivity.this);
textView.setText(student.toString());
textView.setTextSize(18);
return textView;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
}
}