編輯:關於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,將在後面的學習筆記中介紹。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
Handler是開發人員在面試過程中最常見的問題之一了,這篇文章將較為全面地對Handler進行解讀,包括源碼層,以及使用方法。如果看完文章有疑問,歡迎在評論中一起探討基
不是自己不想總結,是因為這篇博客總結的太好了,自己總結估計總結不到這麼全。所以轉來分享。謝謝該博主的共享精神。開篇如下:在Android中實現異步任務機制有兩種方式,Ha
最近學習android時發現,很多書上都介紹了preference首選項這個東西,但是大部分的書都是直接上來講怎麼用,對其的用途和來歷都是只字不提,筆者本人對於這種做法是
問題背景: 參考鏈接 做了一個圖片浏覽,用ContentResolver掃描圖庫照片,且嚴格按照時間拍攝順序排好序顯示在listview裡。如下圖所示:遇到的問題是在4.