文章概述:
1.前提
2.什么是item復用
3.為什么會錯亂
4.解決錯亂
前提
最近幾日一直在忙于面試关顷,各種奇奇怪怪的問題也讓我明白了自己的一些不足详囤。沒辦法,不懂就要學習畸写,這也算是提高自己的一種方式吧贴铜。
昨天面試一家直播app公司的時候面試官問了我這樣一個問題:
在一個listview里每個item中都有一個動畫(gif)播放的view肤频,當我點擊item中的button時動畫(gif)播放叹括。當有動畫播放時滑動listview,偶爾會發(fā)生item錯位的事件着裹。
問:原因是什么领猾,如何解決?
當我聽完這個問題后隨口便說道“這是item復用的問題骇扇,由于異步加載導致圖片錯位”
對于接觸Android一段時間的同學可能都應該知道listview優(yōu)化時會用到item復用摔竿,但是原理可能不太清楚,接下來我們就來先說一下究竟什么是“item復用”
什么是item復用
在我們平常編寫adapter時一般會重寫他的個getView()這個方法
在這段代碼中我們首先做的就是去判斷convertView是否為空少孝,那么這個convertView是什么呢继低?
初始化時ListView先請求一個type1視圖(getView),這時的convertView在getView中是空(null)稍走。當item1滑動出屏幕袁翁,并且一個新的項目從屏幕低端上來時,ListView再請求一個type1視圖婿脸。這個時候convertView此時不是空值了粱胜,它的值是item1。你只需設定新的數(shù)據(jù)然后返回convertView狐树,不必重新創(chuàng)建一個視圖焙压。如下圖所示:
為什么會錯亂
明白了item復用的原理后我們就來探究一下錯亂的原因吧,通過查看源碼我們可以得知原來AbListView中獲取getView()和滑動操作是異步進行的抑钟,其中滑動操作在一個FlingRunnable的支線程中運行涯曲,所以這就導致了在ListView在滑動時可能已經(jīng)滑動到了第十行,但可能第二行的數(shù)據(jù)這時就被直接使用了在塔,這就是導致數(shù)據(jù)加載錯亂的根本原因幻件。
源碼的注解如圖所示:
由于滑動和加載是異步進行的,這樣就會出現(xiàn)一些意想不到的問題:
a. 行item圖片顯示重復
b. 行item圖片顯示錯亂
c. 行item圖片顯示閃爍
解決錯亂
知道了錯亂的原因蛔溃,那么解決起來應該就很簡單了绰沥,我們可以給圖片設置tag來避免數(shù)據(jù)錯亂
當然還有其他的解決辦法比如使用第三方的圖片加載庫來加載圖片一樣可以解決篱蝇。