android listview優(yōu)化幾種寫法詳細(xì)介紹
更新時間:2012年11月12日 14:28:53 作者:
這篇文章只是總結(jié)下getView里面優(yōu)化視圖的幾種寫法,需要的朋友可以參考下
這篇文章只是總結(jié)下getView里面優(yōu)化視圖的幾種寫法,就像孔乙己寫茴香豆的茴字的幾種寫法一樣,高手勿噴,勿笑,只是拿出來分享,有錯誤的地方歡迎大家指正,謝謝。
listview
Aviewthatshowsitemsinaverticallyscrollinglist。
一個顯示一個垂直的滾動子項的列表視圖在android開發(fā)中,使用listview的地方很多,用它來展現(xiàn)數(shù)據(jù),成一個垂直的視圖。使用listview是一個標(biāo)準(zhǔn)的適配器模式,用數(shù)據(jù)--,界面--xml以及適配器--adapter,數(shù)據(jù)被適配器按照需要的方式展現(xiàn)出來,xml描寫了數(shù)據(jù)如何展現(xiàn),activity中控制這些活動。
其中使用自定義的adapter,會要重寫getView方法,在getView方法產(chǎn)生給用戶item的視圖以及數(shù)據(jù)。
見圖:
這里有一個優(yōu)化的地方,就是重用view,這樣減少內(nèi)存消耗,同時加快item加載速度。
在getView中優(yōu)化的地方,大家想必都非常情況,下面我總結(jié)了三種優(yōu)化的寫法,請大家指正。
第一:
重用了convertView,很大程度上的減少了內(nèi)存的消耗。通過判斷convertView是否為null,是的話就需要產(chǎn)生一個視圖出來,然后給這個視圖數(shù)據(jù),最后將這個視圖返回給底層,呈獻(xiàn)給用戶。
特點:如果當(dāng)前的convertView為null,則通過LayoutInflat產(chǎn)生一個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;
}
第二:
上面的寫法會有一個缺點,就是每次在getVIew的時候,都需要重新的findViewById,重新找到控件,然后進(jìn)行控件的賦值以及事件相應(yīng)設(shè)置。這樣其實在做重復(fù)的事情,因為的geiview中,其實包含有這些控件,而且這些控件的id還都是一樣的,也就是其實只要在view中findViewById一次,后面無需要每次都要findViewById了。
下面給出第二種寫法
寫發(fā)的特點,通常有一個內(nèi)部類classViewHolder,這個ViewHolder,用來標(biāo)識view中一些控件,方便進(jìn)行一些事件相應(yīng)操作的設(shè)置,比如onClick等等,這樣可以不用每次都要findViewById了,減少了性能的消耗。同時重用了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;
}
第三:
個人覺得這個寫法是最舒服的,最舒服的意思是看著代碼有一種很爽,看的很清晰。
特點,使用了內(nèi)部類classViewHolder、重用了convertView。
區(qū)別第二種寫法是,使用了一個臨時變量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)類只會在第一次加載時會耗費(fèi)比較長時間,但是后面就可以很好幫助加載,同時保證了內(nèi)存中只有一個ViewHolder,節(jié)省了內(nèi)存的開銷。
非常感謝大家提出建議以及大家的關(guān)注!
listview
Aviewthatshowsitemsinaverticallyscrollinglist。
一個顯示一個垂直的滾動子項的列表視圖在android開發(fā)中,使用listview的地方很多,用它來展現(xiàn)數(shù)據(jù),成一個垂直的視圖。使用listview是一個標(biāo)準(zhǔn)的適配器模式,用數(shù)據(jù)--,界面--xml以及適配器--adapter,數(shù)據(jù)被適配器按照需要的方式展現(xiàn)出來,xml描寫了數(shù)據(jù)如何展現(xiàn),activity中控制這些活動。
其中使用自定義的adapter,會要重寫getView方法,在getView方法產(chǎn)生給用戶item的視圖以及數(shù)據(jù)。
見圖:
這里有一個優(yōu)化的地方,就是重用view,這樣減少內(nèi)存消耗,同時加快item加載速度。
在getView中優(yōu)化的地方,大家想必都非常情況,下面我總結(jié)了三種優(yōu)化的寫法,請大家指正。
第一:
重用了convertView,很大程度上的減少了內(nèi)存的消耗。通過判斷convertView是否為null,是的話就需要產(chǎn)生一個視圖出來,然后給這個視圖數(shù)據(jù),最后將這個視圖返回給底層,呈獻(xiàn)給用戶。
特點:如果當(dāng)前的convertView為null,則通過LayoutInflat產(chǎn)生一個view。
復(fù)制代碼 代碼如下:
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;
}
第二:
上面的寫法會有一個缺點,就是每次在getVIew的時候,都需要重新的findViewById,重新找到控件,然后進(jìn)行控件的賦值以及事件相應(yīng)設(shè)置。這樣其實在做重復(fù)的事情,因為的geiview中,其實包含有這些控件,而且這些控件的id還都是一樣的,也就是其實只要在view中findViewById一次,后面無需要每次都要findViewById了。
下面給出第二種寫法
寫發(fā)的特點,通常有一個內(nèi)部類classViewHolder,這個ViewHolder,用來標(biāo)識view中一些控件,方便進(jìn)行一些事件相應(yīng)操作的設(shè)置,比如onClick等等,這樣可以不用每次都要findViewById了,減少了性能的消耗。同時重用了convertView,很大程度上的減少了內(nèi)存的消耗。
復(fù)制代碼 代碼如下:
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;
}
第三:
個人覺得這個寫法是最舒服的,最舒服的意思是看著代碼有一種很爽,看的很清晰。
特點,使用了內(nèi)部類classViewHolder、重用了convertView。
區(qū)別第二種寫法是,使用了一個臨時變量Viewview=convertView,然后修改view,最后返回view
復(fù)制代碼 代碼如下:
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)化的地方,最新更新如下:
復(fù)制代碼 代碼如下:
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)類只會在第一次加載時會耗費(fèi)比較長時間,但是后面就可以很好幫助加載,同時保證了內(nèi)存中只有一個ViewHolder,節(jié)省了內(nèi)存的開銷。
非常感謝大家提出建議以及大家的關(guān)注!
您可能感興趣的文章:
- Android文本視圖TextView實現(xiàn)跑馬燈效果
- Android使用ViewBinding的詳細(xì)步驟(Kotlin簡易版)
- Android使用ViewPager實現(xiàn)啟動引導(dǎo)頁效果
- Android實現(xiàn)view拖動到任意位置
- Android OpenGL入門之GLSurfaceView
- android TextView設(shè)置中文字體加粗實現(xiàn)方法
- android WebView加載html5介紹
- android imageview圖片居中技巧應(yīng)用
- Android TextView設(shè)置背景色與邊框的方法詳解
- Android view繪制流程詳解
相關(guān)文章
Android開發(fā)經(jīng)驗談:并發(fā)編程(線程與線程池)(推薦)
這篇文章主要介紹了Android開發(fā)經(jīng)驗談:并發(fā)編程(線程與線程池),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Android ConnectivityManager網(wǎng)絡(luò)管理詳解
在android平臺中ConnectivityManager主要負(fù)責(zé)查詢網(wǎng)絡(luò)連接狀態(tài)以及在連接狀態(tài)有變化的時候發(fā)出通知,這篇文章主要介紹了Android ConnectivityManager網(wǎng)絡(luò)管理2022-11-11
Kotlin中l(wèi)et()with()run()apply()also()函數(shù)的使用方法與區(qū)別
在Kotlin中的源碼標(biāo)準(zhǔn)庫(Standard.kt)中提供了一些Kotlin擴(kuò)展的內(nèi)置函數(shù)可以優(yōu)化kotlin的編碼,今天為大家聊聊let,with,run,apply,also幾個函數(shù)的用法與區(qū)別2018-03-03
Android實現(xiàn)上傳文件到服務(wù)器實例詳解
本篇文章詳細(xì)介紹了Android實現(xiàn)上傳文件到服務(wù)器實例詳解,實現(xiàn)了文件每隔5秒進(jìn)行上傳,有需要的可以了解一下。2016-11-11
Android?源碼淺析RecyclerView?Adapter
這篇文章主要介紹了Android?源碼淺析之RecyclerView?Adapter示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Android ListView與ScrollView沖突的解決方法總結(jié)
這篇文章主要介紹了Android ListView與ScrollView沖突的解決方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-04-04
Android Intent傳遞對象的兩種方法(Serializable,Parcelable)詳細(xì)介紹
這篇文章主要介紹了Android Intent傳遞對象的兩種方法(Serializable,Parcelable)詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-12-12

