LsitView和Adapter
參考:http://www.cnblogs.com/xiaowenji/archive/2010/12/08/1900579.html工作原理: 1.ListView針對List中每個item,要求adapter給我一個視圖(getView) 2.一個新的視圖被返回並顯示
如果我們有上億個item要顯示怎麼辦?為每個項目建立一個新視圖?NO!這不可能~~~Android實際上為你緩衝了視圖
Android中有個叫做Recycler(反覆迴圈器)的構件,是它的工作原理:1.如果你有10億個項目(item),其中只有可見的項目存在記憶體中,其他的在Recycler中2.ListView先請求一個type1視圖(getView),然後請求其他可見的項目。conVertView在getView中時null的3.當item1滾出螢幕,並且一個新的項目從螢幕地段上來時,ListView再請求一個type1視圖。convertView此時不是空值了,它的值是item1.你只需要設定新的資料返回convertView,不必重新建立一個視圖。這樣直接使用convertView從而減少了很不不必要view的建立
!!!!!!更快的方式是定義一個ViewHolder,將convertView的tag設定為ViewHolder,不為空白是重新使用
ViewHolder只是將需要緩衝的那些view封裝好,convertView的setTag才是將這些緩衝起來供下次調用
當你的listview裡布局多樣化的時候 viewholder的作用就有比較明顯的體現了。 當然了,單一模式的布局一樣有效能最佳化的作用 只是不直觀。 假如你2種模式的布局 當發生回收的時候 你會用setTag分別記錄是哪兩種
這兩種模式會被封裝到viewholder中進行儲存方便你下次使用。 VH就是個靜態類 與緩衝無關的
public class MultipleItemsList extends ListActivity { private MyCustomAdapter mAdapter; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mAdapter = new MyCustomAdapter(); for (int i = 0; i < 50; i++) { mAdapter.addItem("item " + i); } setListAdapter(mAdapter); } private class MyCustomAdapter extends BaseAdapter { private ArrayList mData = new ArrayList(); private LayoutInflater mInflater; public MyCustomAdapter() { mInflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE); } public void addItem(final String item) { mData.add(item); notifyDataSetChanged(); } @Override public int getCount() { return mData.size(); } @Override public String getItem(int position) { return mData.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { System.out.println("getView " + position + " " + convertView); ViewHolder holder = null; if (convertView == null) { convertView = mInflater.inflate(R.layout.item1, null); holder = new ViewHolder(); holder.textView = (TextView)convertView.findViewById(R.id.text); convertView.setTag(holder); } else { holder = (ViewHolder)convertView.getTag(); } holder.textView.setText(mData.get(position)); return convertView; } } public static class ViewHolder { public TextView textView; }}
參考資料:
http://www.cnblogs.com/xiaowenji/archive/2010/12/08/1900579.html
http://www.eoeandroid.com/thread-72369-1-1.html
http://www.cnblogs.com/felix-hua/archive/2012/01/06/2314436.html
http://blog.csdn.net/jacman/article/details/7087995
http://fatkun.com/2012/01/android-viewholder.html
以上分析都是晚上搜刮加綜合再加理解,希望看到這篇文章的朋友,多分享,多指教。。。