ListView中convertView和ViewHolder的工作原理
生活随笔
收集整理的這篇文章主要介紹了
ListView中convertView和ViewHolder的工作原理
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
w和Adapter
參考:http://www.cnblogs.com/xiaowenji/archive/2010/12/08/1900579.html
工作原理:
?1.ListView針對(duì)List中每個(gè)item,要求adapter給我一個(gè)視圖(getView)
?2.一個(gè)新的視圖被返回并顯示
如果我們有上億個(gè)item要顯示怎么辦?為每個(gè)項(xiàng)目創(chuàng)建一個(gè)新視圖?NO!這不可能~~~Android實(shí)際上為你緩存了視圖
Android中有個(gè)叫做Recycler(反復(fù)循環(huán)器)的構(gòu)件,下圖是它的工作原理:
1.如果你有10億個(gè)項(xiàng)目(item),其中只有可見的項(xiàng)目存在內(nèi)存中,其他的在Recycler中 2.ListView先請(qǐng)求一個(gè)type1視圖(getView),然后請(qǐng)求其他可見的項(xiàng)目。conVertView在getView中時(shí)null的 3.當(dāng)item1滾出屏幕,并且一個(gè)新的項(xiàng)目從屏幕地段上來時(shí),ListView再請(qǐng)求一個(gè)type1視圖。convertView此時(shí)不是空值了,它的值是item1.你只需要設(shè)定新的數(shù)據(jù)返回convertView,不必重新創(chuàng)建一個(gè)視圖。這樣直接使用convertView從而減少了很不不必要view的創(chuàng)建
!!!!!!更快的方式是定義一個(gè)ViewHolder,將convertView的tag設(shè)置為ViewHolder,不為空是重新使用
ViewHolder只是將需要緩存的那些view封裝好,convertView的setTag才是將這些緩存起來供下次調(diào)用 當(dāng)你的listview里布局多樣化的時(shí)候 viewholder的作用就有比較明顯的體現(xiàn)了。 當(dāng)然了,單一模式的布局一樣有性能優(yōu)化的作用 只是不直觀。??假如你2種模式的布局 當(dāng)發(fā)生回收的時(shí)候 你會(huì)用setTag分別記錄是哪兩種? ?這兩種模式會(huì)被封裝到viewholder中進(jìn)行保存方便你下次使用。 VH就是個(gè)靜態(tài)類 與緩存無關(guān)的
[java]?view plaincopy print? <span?style="font-family:Microsoft?YaHei;font-size:18px;color:#3366ff;"><strong>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;?? ????}?? }</strong></span>??
如果我們有上億個(gè)item要顯示怎么辦?為每個(gè)項(xiàng)目創(chuàng)建一個(gè)新視圖?NO!這不可能~~~Android實(shí)際上為你緩存了視圖
Android中有個(gè)叫做Recycler(反復(fù)循環(huán)器)的構(gòu)件,下圖是它的工作原理:
1.如果你有10億個(gè)項(xiàng)目(item),其中只有可見的項(xiàng)目存在內(nèi)存中,其他的在Recycler中 2.ListView先請(qǐng)求一個(gè)type1視圖(getView),然后請(qǐng)求其他可見的項(xiàng)目。conVertView在getView中時(shí)null的 3.當(dāng)item1滾出屏幕,并且一個(gè)新的項(xiàng)目從屏幕地段上來時(shí),ListView再請(qǐng)求一個(gè)type1視圖。convertView此時(shí)不是空值了,它的值是item1.你只需要設(shè)定新的數(shù)據(jù)返回convertView,不必重新創(chuàng)建一個(gè)視圖。這樣直接使用convertView從而減少了很不不必要view的創(chuàng)建
!!!!!!更快的方式是定義一個(gè)ViewHolder,將convertView的tag設(shè)置為ViewHolder,不為空是重新使用
ViewHolder只是將需要緩存的那些view封裝好,convertView的setTag才是將這些緩存起來供下次調(diào)用 當(dāng)你的listview里布局多樣化的時(shí)候 viewholder的作用就有比較明顯的體現(xiàn)了。 當(dāng)然了,單一模式的布局一樣有性能優(yōu)化的作用 只是不直觀。??假如你2種模式的布局 當(dāng)發(fā)生回收的時(shí)候 你會(huì)用setTag分別記錄是哪兩種? ?這兩種模式會(huì)被封裝到viewholder中進(jìn)行保存方便你下次使用。 VH就是個(gè)靜態(tài)類 與緩存無關(guān)的
[java]?view plaincopy print?
參考資料:
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
總結(jié)
以上是生活随笔為你收集整理的ListView中convertView和ViewHolder的工作原理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: s7200cpu224xp手册_S7-2
- 下一篇: 移动互联智慧杭州、技术精英引领中国