tableView的優(yōu)化

tableView優(yōu)化:

1.cell的重用

2.dequeueReusableCellWithIdentifier:forIndexPath:(會調(diào)用heightForRowAtIndexPath)和dequeueReusableCellWithIdentifier (后面這個不會再次調(diào)用heightForRowAtIndexPath)

2.1 tableView在cell顯示之前會調(diào)用heightForRowAtIndexPath,有多少個cell就會調(diào)用多少次,算contentSize

2.2使用了預(yù)估行高,并不會在顯示之前去計(jì)算獲取所有的行高(預(yù)估行高,等cell要顯示的時候才回去計(jì)算真實(shí)的高度),根據(jù)預(yù)估行高和實(shí)際行高來獲取cell的行高,先根據(jù)預(yù)估行高計(jì)算好要先獲取幾個cell,如果計(jì)算的這幾個cell高度確實(shí)夠(高度能超出屏幕的高度就不計(jì)算了.如果不夠還會計(jì)算),目的也是讓contentSize大于屏幕,就能滾動,后面要顯示,才來計(jì)算行高,所以會發(fā)現(xiàn)滾動條會跳

3.cell的高度是根據(jù)內(nèi)容變化的時候,只計(jì)算一次,將高度緩存起來

overridefunctableView(tableView:UITableView, heightForRowAtIndexPath indexPath:NSIndexPath) ->CGFloat{

//獲取模型

letstatus =self.statuses![indexPath.row]

//判斷模型里面之前有沒有緩存過行高

ifstatus.rowHeight!=nil

{

//之前保存過行高,直接返回行高

returnstatus.rowHeight!

}

//自己計(jì)算行高:AutoLayout自動約束

//讓cell設(shè)置對應(yīng)內(nèi)容,可以直接直接獲取,這個cell不參與顯示

letcell = tableView.dequeueReusableCellWithIdentifier(ReuseIndentifier)as!HMStatusCell

cell.status= status

letheight = cell.systemLayoutSizeFittingSize(UILayoutFittingCompressedSize).height

status.rowHeight= height

returnheight

}

4.下載圖片使用SDWebImage(異步操作)

5.cellForRowAtIndexPath不要做耗時操作

1.讀取文件,寫入文件,最好是放到子線程,或先讀取好,在讓tableView去顯示

2.盡量不要再這個方法里解壓資源

3.盡量少得計(jì)算計(jì)算,最好是先計(jì)算好,cellForRowAtIndexPath只做顯示

4.盡量不要去添加和移除view,現(xiàn)將會用到的控件懶加載,要就顯示,不要就隱藏

6.tableView滾動的時候,不要去做動畫(微信的聊天界面做的就很好,在滾動的時候,動態(tài)圖就不讓他動,滾動停止的時候才動,不然可能會有點(diǎn)影響流暢度)

7.cell里面的控件,約束最好不要使用remake,動態(tài)添加約束是比較耗性能的

8.cell里面的控件,背景最好是不透明的(圖層混合靠GPU去渲染,會影響性能,綠色的好,紅色的性能差), view的背景顏色clearColor盡量少

9.圖片圓角不要使用layer.cornerRadius,因?yàn)橥ㄟ^圖層去渲染的話都會影響性能

10.圖層最好不要使用陰影,陰影會導(dǎo)致離屏渲染(在進(jìn)入屏幕渲染之前,還看不到的時候會再渲染一次,盡量不要產(chǎn)生離屏渲染)

11.異步繪制

12.柵格化

13.借助工具來測試性能

14.AsyncDisplayKit ->不使用UIKit (UIView) ->? (Node)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚀同,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子捂龄,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件挂脑,死亡現(xiàn)場離奇詭異迫肖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)闲坎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門疫粥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人腰懂,你說我怎么就攤上這事梗逮。” “怎么了绣溜?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵慷彤,是天一觀的道長。 經(jīng)常有香客問我怖喻,道長底哗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任锚沸,我火速辦了婚禮跋选,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘哗蜈。我一直安慰自己前标,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布距潘。 她就那樣靜靜地躺著炼列,像睡著了一般。 火紅的嫁衣襯著肌膚如雪音比。 梳的紋絲不亂的頭發(fā)上唯鸭,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天,我揣著相機(jī)與錄音硅确,去河邊找鬼目溉。 笑死,一個胖子當(dāng)著我的面吹牛菱农,可吹牛的內(nèi)容都是我干的缭付。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼循未,長吁一口氣:“原來是場噩夢啊……” “哼陷猫!你這毒婦竟也來了秫舌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绣檬,失蹤者是張志新(化名)和其女友劉穎足陨,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體娇未,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡墨缘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了零抬。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片镊讼。...
    茶點(diǎn)故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖平夜,靈堂內(nèi)的尸體忽然破棺而出蝶棋,到底是詐尸還是另有隱情,我是刑警寧澤忽妒,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布玩裙,位于F島的核電站,受9級特大地震影響段直,放射性物質(zhì)發(fā)生泄漏献酗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一坷牛、第九天 我趴在偏房一處隱蔽的房頂上張望罕偎。 院中可真熱鬧,春花似錦京闰、人聲如沸颜及。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽俏站。三九已至,卻和暖如春痊土,著一層夾襖步出監(jiān)牢的瞬間肄扎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工赁酝, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留犯祠,地道東北人。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓酌呆,卻偏偏與公主長得像衡载,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子隙袁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容