編輯:關於Android編程
上一篇中我們介紹了自定義實現BaseAdapter的普通實現布局,然而上一章也說了普通實現的方式效率會很低,而且對系統開銷也很大,所以,那樣的實現是為了讓初學者能知道可以這樣使用,在實際項目中不可能使用那種方式的,要是你在做項目的時候使用普通布局方式,我敢保證,不過試用期你的老板就給你飛機票走人了,好了,閒話少說,本次講解一下優化布局的實現,看完代碼後,你會覺得,其實很簡單。
MainActivity.java
public class MainActivity extends AppCompatActivity {
private List<Student> data;
private ListView mList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mList = (ListView)findViewById(R.id.mList);
data = new ArrayList<>();
Student stu = null;
for(int i = 0; i < 5; i ++){
stu = new Student();
stu.setName("姓名"+ i);
stu.setSex(i % 2 == 0 ? "男" : "女");
data.add(stu);
}
MyAdapter adapter = new MyAdapter(data);
mList.setAdapter(adapter);
}
}
MyAdapter.java
public class MyAdapter extends BaseAdapter {
private List<Student> data;
public MyAdapter(List<Student> data) {
this.data = data;
}
@Override
public int getCount() {
return data == null ? 0 : data.size();
}
@Override
public Object getItem(int position) {
return data.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
/**
*
* @param position
* @param convertView
* @param parent
* @return
*/
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if(convertView == null){
//解析布局
convertView = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item,null);
//創建ViewHolder持有類
holder = new ViewHolder();
//將每個控件的對象保存到持有類中
holder.tvName = (TextView)convertView.findViewById(R.id.mTv1);
holder.tvSex = (TextView)convertView.findViewById(R.id.mTv2);
//將每個convertView對象中設置這個持有類對象
convertView.setTag(holder);
}
//每次需要使用的時候都會拿到這個持有類
holder = (ViewHolder)convertView.getTag();
//然後可以直接使用這個類中的控件,對控件進行操作,而不用重復去findViewById了
holder.tvName.setText(data.get(position).getName());
holder.tvSex.setText(data.get(position).getSex());
return convertView;
}
/**
* 通過這個類來保存當前所有的控件id
*/
static class ViewHolder{
TextView tvName;
TextView tvSex;
}
}
上面的代碼實現很簡單,只是借助了一個ViewHolder持有類來保存每個布局中的控件ID就可以,也正如我們在上一篇普通實現BaseAdapter的第二種實現方式中所說的雖然使解析的次數降低到最少,但是每次都要findViewById,而這裡的優化就剛好是針對那種方式的優化,這樣一來,解析次數已經達到了最少,findViewById的次數也達到了最少,不過對於適配器來說,沒有最優,只有更優,也就是說,如果以後我們在寫ListView布局的的時候,每次都用這種方式去實現是非常方便,效率也不錯,每寫一個ListView處理不同的數據都要去自定義BaseAdapter,如果說一兩個還好,要是你的項目中有20個處理不同數據的ListView,那麼是不是要寫20個自定義BaseAdapter呢?所以,為了方便開發,我們可以打造一個通用的BaseAdapter,關於如何打造一個通用的BaseAdapter,將在後面的學習筆記中介紹。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
Android消息機制Handler解析(源碼+Demo)
Handler是開發人員在面試過程中最常見的問題之一了,這篇文章將較為全面地對Handler進行解讀,包括源碼層,以及使用方法。如果看完文章有疑問,歡迎在評論中一起探討基
詳解Android中AsyncTask的使用
不是自己不想總結,是因為這篇博客總結的太好了,自己總結估計總結不到這麼全。所以轉來分享。謝謝該博主的共享精神。開篇如下:在Android中實現異步任務機制有兩種方式,Ha
詳解Android應用中preference首選項的編寫方法
最近學習android時發現,很多書上都介紹了preference首選項這個東西,但是大部分的書都是直接上來講怎麼用,對其的用途和來歷都是只字不提,筆者本人對於這種做法是
Android4.4 ContentResolver查詢圖片無效 及 圖庫刪除 增加圖片後,ContentResolver不更新的問題解決
問題背景: 參考鏈接 做了一個圖片浏覽,用ContentResolver掃描圖庫照片,且嚴格按照時間拍攝順序排好序顯示在listview裡。如下圖所示:遇到的問題是在4.