ym——Android之ListView性能优化
生活随笔
收集整理的這篇文章主要介紹了
ym——Android之ListView性能优化
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
轉載請注明本文出自Cym的博客(http://blog.csdn.net/cym492224103),謝謝支持!
Android之ListView性能優化
假設有看過我寫過的15k面試題的朋友們一定知道。ListView的優化方式有下面幾種:
接下來我具體的說一下。這個是怎樣優化的。
重用了convertView getView這種方法會調用的次數是你們的數據條目數*2,重用了convertView,非常大程度上的降低了內存的消耗。通過推斷convertView是否為null,是的話就須要產生一個視圖出來,然后給這個視圖數據,最后將這個視圖返回給底層,呈獻給用戶。? 特點:假設當前的convertView為null,則通過LayoutInflat產生一個view。? <span style="font-size:14px;">public View getView(int position,View convertView,ViewGroup parent) { if(convertView==null) { convertView=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null); } TextViewtv_name=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_name); TextViewtv_phone=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); ContactInfo1confo=contacts.get(position); if(confo!=null){//toseteveryitem'stext tv_name.setText(confo.getContactName()); tv_phone.setText(confo.getContact_Phone()); } return convertView; }</span><span style="font-size: 24px;"> </span>ViewHolder 上面的寫法會有一個缺點,就是每次在getVIew的時候,都須要又一次的findViewById。又一次找到控件,然后進行控件的賦值以及事件對應設置。這樣事實上在做反復的事情。由于的geiview中。事實上包括有這些控件,并且這些控件的id還都是一樣的,也就是事實上僅僅要在view中findViewById一次,后面無須要每次都要findViewById了。? 以下給出另外一種寫法? 寫發的特點,通常有一個內部類classViewHolder,這個ViewHolder,用來標識view中一些控件,方便進行一些事件對應操作的設置,比方onClick等等,這樣能夠不用每次都要findViewById了,降低了性能的消耗。同一時候重用了convertView。非常大程度上的降低了內存的消耗。? <span style="font-size:14px;">public View getView(int position,View convertView,ViewGroup parent) { ViewHolderholder; if(convertView==null){ convertView=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null); holder=newViewHolder(); holder.tv_name=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_name); holder.tv_phone=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); convertView.setTag(holder); } else { holder=(ViewHolder)convertView.getTag(); } ContactInfo1confo=contacts.get(position); Log.i("my","confo"+confo.getContactName()); if(confo!=null){//toseteveryitem'stext holder.tv_name.setText(confo.getContactName()); holder.tv_phone.setText(confo.getContact_Phone()); } return convertView; } classViewHolder { TextViewtv_name,tv_phone; } </span>
static class ViewHolder 把以上兩種結合起來。然后把ViewHolder為static,也就是靜態的,靜態類僅僅會在第一次載入時會耗費比較長時間??墒呛竺婢湍軌蚍浅:脦椭d入, 同一時候保證了內存中僅僅有一個ViewHolder,節省了內存的開銷。? 我們會發現不管是什么adapter都是這些優化的方式,所以大家肯定思考會沒有一種方法能夠把代碼重用的部分抽出來, 假設有這樣的想法的朋友能夠看下我寫的這篇adapter代碼優化 在列表里面有圖片的情況下,監聽滑動不載入圖片 還有一種情況,就是一個列表載入非常多圖片,在圖片還沒載入下來的時候,高速的滑動列表,會發現卡頓的現象發生。 這樣的情況我們就須要監聽。ListView的滑動監聽里面設置不載入圖片。滑動停止開始載入。 1、推斷listView狀態 AbsListView.OnScrollListener onScrollListener = new AbsListView.OnScrollListener() {// ListView // 觸摸事件public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { }public void onScrollStateChanged(AbsListView view, int scrollState) { switch (scrollState) { case AbsListView.OnScrollListener.SCROLL_STATE_FLING:// 滑動狀態 threadFlag = false; break; case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:// 停止 threadFlag = true; startThread(); break; case AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:// 觸摸listView threadFlag = false; break; default: // Toast.makeText(contextt, "default", // Toast.LENGTH_SHORT).show(); break; } } }; 2、獲取當前屏幕上顯示的items: mListView.getFirstVisiblePosition(); mListView.getLastVisiblePosition();
版權聲明:本文博主原創文章,博客,未經同意不得轉載。
轉載于:https://www.cnblogs.com/bhlsheji/p/4913145.html
總結
以上是生活随笔為你收集整理的ym——Android之ListView性能优化的全部內容,希望文章能夠幫你解決所遇到的問題。