android listview優(yōu)化幾種寫法詳細(xì)介紹
listview
Aviewthatshowsitemsinaverticallyscrollinglist。
一個(gè)顯示一個(gè)垂直的滾動(dòng)子項(xiàng)的列表視圖在android開發(fā)中,使用listview的地方很多,用它來(lái)展現(xiàn)數(shù)據(jù),成一個(gè)垂直的視圖。使用listview是一個(gè)標(biāo)準(zhǔn)的適配器模式,用數(shù)據(jù)--,界面--xml以及適配器--adapter,數(shù)據(jù)被適配器按照需要的方式展現(xiàn)出來(lái),xml描寫了數(shù)據(jù)如何展現(xiàn),activity中控制這些活動(dòng)。
其中使用自定義的adapter,會(huì)要重寫getView方法,在getView方法產(chǎn)生給用戶item的視圖以及數(shù)據(jù)。
見圖:
這里有一個(gè)優(yōu)化的地方,就是重用view,這樣減少內(nèi)存消耗,同時(shí)加快item加載速度。
在getView中優(yōu)化的地方,大家想必都非常情況,下面我總結(jié)了三種優(yōu)化的寫法,請(qǐng)大家指正。
第一:
重用了convertView,很大程度上的減少了內(nèi)存的消耗。通過(guò)判斷convertView是否為null,是的話就需要產(chǎn)生一個(gè)視圖出來(lái),然后給這個(gè)視圖數(shù)據(jù),最后將這個(gè)視圖返回給底層,呈獻(xiàn)給用戶。
特點(diǎn):如果當(dāng)前的convertView為null,則通過(guò)LayoutInflat產(chǎn)生一個(gè)view。
ViewCode
publicViewgetView(intposition,ViewconvertView,ViewGroupparent)
{
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());
}
returnconvertView;
}
第二:
上面的寫法會(huì)有一個(gè)缺點(diǎn),就是每次在getVIew的時(shí)候,都需要重新的findViewById,重新找到控件,然后進(jìn)行控件的賦值以及事件相應(yīng)設(shè)置。這樣其實(shí)在做重復(fù)的事情,因?yàn)榈膅eiview中,其實(shí)包含有這些控件,而且這些控件的id還都是一樣的,也就是其實(shí)只要在view中findViewById一次,后面無(wú)需要每次都要findViewById了。
下面給出第二種寫法
寫發(fā)的特點(diǎn),通常有一個(gè)內(nèi)部類classViewHolder,這個(gè)ViewHolder,用來(lái)標(biāo)識(shí)view中一些控件,方便進(jìn)行一些事件相應(yīng)操作的設(shè)置,比如onClick等等,這樣可以不用每次都要findViewById了,減少了性能的消耗。同時(shí)重用了convertView,很大程度上的減少了內(nèi)存的消耗。
ViewCode
publicViewgetView(intposition,ViewconvertView,ViewGroupparent)
{
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());
}
returnconvertView;
}
classViewHolder
{
TextViewtv_name,tv_phone;
}
第三:
個(gè)人覺(jué)得這個(gè)寫法是最舒服的,最舒服的意思是看著代碼有一種很爽,看的很清晰。
特點(diǎn),使用了內(nèi)部類classViewHolder、重用了convertView。
區(qū)別第二種寫法是,使用了一個(gè)臨時(shí)變量Viewview=convertView,然后修改view,最后返回view
ViewCode
@Override
publicViewgetView(intposition,ViewconvertView,ViewGroupparent)
{
Viewview=convertView;
ViewHolderholder;
if(view==null){
view=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null);
holder=newViewHolder();
holder.tv_name=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_name);
holder.tv_phone=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_phoneNum);
view.setTag(holder);
}
else
{
holder=(ViewHolder)view.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());
}
returnview;
}
classViewHolder
{
TextViewtv_name,tv_phone;
}
以上就是集中寫法,供新手學(xué)習(xí)和總結(jié)。
源代碼如下:LisViewTest.zip
根據(jù)樓下朋友提供的建議,發(fā)現(xiàn)還有優(yōu)化的地方,最新更新如下:
ViewCode
@Override
publicViewgetView(intposition,ViewconvertView,ViewGroupparent)
{
Viewview=convertView;
ViewHolderholder;
if(view==null){
view=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null);
holder=newViewHolder();
holder.tv_name=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_name);
holder.tv_phone=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_phoneNum);
view.setTag(holder);
}
else
{
holder=(ViewHolder)view.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());
}
returnview;
}
<fontcolor="\"#0000ff\""></font>staticclassViewHolder
{
TextViewtv_name,tv_phone;
}
注意:staticclassViewHolder
這里設(shè)置ViewHolder為static,也就是靜態(tài)的,靜態(tài)類只會(huì)在第一次加載時(shí)會(huì)耗費(fèi)比較長(zhǎng)時(shí)間,但是后面就可以很好幫助加載,同時(shí)保證了內(nèi)存中只有一個(gè)ViewHolder,節(jié)省了內(nèi)存的開銷。
非常感謝大家提出建議以及大家的關(guān)注!
- Android文本視圖TextView實(shí)現(xiàn)跑馬燈效果
- Android使用ViewBinding的詳細(xì)步驟(Kotlin簡(jiǎn)易版)
- Android使用ViewPager實(shí)現(xiàn)啟動(dòng)引導(dǎo)頁(yè)效果
- Android實(shí)現(xiàn)view拖動(dòng)到任意位置
- Android OpenGL入門之GLSurfaceView
- android TextView設(shè)置中文字體加粗實(shí)現(xiàn)方法
- android WebView加載html5介紹
- android imageview圖片居中技巧應(yīng)用
- Android TextView設(shè)置背景色與邊框的方法詳解
- Android view繪制流程詳解
相關(guān)文章
在Android上實(shí)現(xiàn)HttpServer的示例代碼
本篇文章主要介紹了在Android上實(shí)現(xiàn)HttpServer的示例代碼,實(shí)現(xiàn)Android本地的微型服務(wù)器,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
OpenHarmony如何調(diào)用電話服務(wù)API撥打電話
OpenHarmony3.1版本標(biāo)準(zhǔn)系統(tǒng)增加了通話相關(guān)的聯(lián)系人應(yīng)用,來(lái)電應(yīng)用等,在系統(tǒng)服務(wù)層面電話相關(guān)功能也比較完善,這篇文章主要介紹了OpenHarmony如何調(diào)用電話服務(wù)API撥打電話2022-11-11
Android實(shí)現(xiàn)頁(yè)面翻轉(zhuǎn)和自動(dòng)翻轉(zhuǎn)功能
這篇文章主要介紹了Android中簡(jiǎn)單實(shí)現(xiàn)頁(yè)面翻轉(zhuǎn)和自動(dòng)翻轉(zhuǎn)的功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10
Android系統(tǒng)檢測(cè)程序內(nèi)存占用各種方法
這篇文章主要介紹了Android系統(tǒng)檢測(cè)程序內(nèi)存占用各種方法,本文講解了檢查系統(tǒng)總內(nèi)存、檢查某個(gè)程序的各類型內(nèi)存占用、檢查程序狀態(tài)、檢查程序各部分的內(nèi)存占用等內(nèi)容,需要的朋友可以參考下2015-03-03
Android手機(jī)端小米推送Demo解析和實(shí)現(xiàn)方法
本篇文章主要是介紹了Android端小米推送Demo解析和實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-10-10
Android實(shí)現(xiàn)訂單倒計(jì)時(shí)功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)訂單倒計(jì)時(shí)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
Android自定義View的使用及其原理知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于Android自定義View的使用及其原理知識(shí)點(diǎn)總結(jié)內(nèi)容,需要的朋友們可以學(xué)習(xí)下。2019-08-08
Android自定義View仿IOS圓盤時(shí)間選擇器
這篇文章主要介紹了Android自定義View仿IOS圓盤時(shí)間選擇器,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03
Android實(shí)現(xiàn)APP環(huán)境分離(利用Gradle)
有過(guò)互聯(lián)網(wǎng)軟件開發(fā)經(jīng)驗(yàn)的朋友一定對(duì)于測(cè)試環(huán)境和生產(chǎn)環(huán)境這兩個(gè)詞很是熟悉,在開發(fā)和測(cè)試階段,我們常常需要在同一個(gè)設(shè)備上同時(shí)安裝著兩套甚至多套環(huán)境的同一個(gè)應(yīng)用,便于觀察調(diào)試。所以這篇文章就來(lái)和大家分享Android利用Gradle實(shí)現(xiàn)APP環(huán)境分離的方法。2016-09-09
Android數(shù)據(jù)加密之Base64編碼算法的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇Android數(shù)據(jù)加密之Base64編碼算法的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10

